如我们都知道的那样,Google的很多网站无法在国内访问。其中包括Android相关的网站,这增加了我们获取,阅读Android源代码的难度。扣丁书屋(https://www.codingsky.com)在前年(2015年)开发了在线阅读Android源代码的网站。本着开源精神,现将这个网站开源。开源地址为:https://github.com/codingskydotcom/aospreader
示例网站如下图所示
当然,你也可以从我们的官方保留站点访问,其地址为http://aosp.codingsky.com
本网站使用Yii框架进行开发,按照Yii框架的部署方式进行部署即可(以下示例都以代码部署到Apache服务器上,路径为/var/www/aosp进行举例):
将代码clone到本地
git clone https://github.com/codingskydotcom/aospreader.git /var/www/aosp/
添加runtime目录并保证web运行账号可读写
mkdir /var/www/aosp/iprogram/protected/runtime
chmod 777 /var/www/aosp/iprogram/protected/runtime/
配置nginx或apache
<VirtualHost *:80>
ServerName aosp.codingsky.com
# ServerAlias aosp.codingsky.com
ServerAdmin webmaster@localhost
DocumentRoot /var/www/aosp/
<Directory /var/www/marmot>
AllowOverride All
</Directory>
ErrorLog ${APACHE_LOG_DIR}/aosp_error.log
CustomLog ${APACHE_LOG_DIR}/aosp_access.log combined
</VirtualHost>
如果一切正常,那么网站应该是可以访问了,此时访问一下站点,如果成功,则可进行后续路径的配置。网站为了提供在线阅读的功能,需要事先将源代码下载到本地。比如下载到本地的/mnt/androidos目录下,则打开之前网站的php文件:{website}/iprogram/protected/models/AndroidOsFileConfig.php
,修改类成员变量androidOsConfig的值即可,此值在类的init方法中被初始化。以源代码下载到/mnt/androidos为例,此文件配置完成后如下所示:
class AndroidOsFileConfig {
private $androidOsConfig = null;
public function __construct(){
$this->init();
}
public function init(){
$this->androidOsConfig = array(
array("sdk" => 9, "name" => "Gingerbread", "dir" => "/mnt/androidos/android-2.3.2_r1"),
array("sdk" => 10, "name" => "Gingerbread MR1", "dir" => "/mnt/androidos/android-2.3.7_r1"),
array("sdk" => 14, "name" => "Ice Cream Sandwich", "dir" => "/mnt/androidos/android-4.0.2_r1"),
array("sdk" => 15, "name" => "Ice Cream Sandwich MR1", "dir" => "/mnt/androidos/android-4.0.4_r2.1"),
array("sdk" => 16, "name" => "Jelly Bean", "dir" => "/mnt/androidos/android-4.1.1_r1"),
array("sdk" => 17, "name" => "Jelly Bean MR1", "dir" => "/mnt/androidos/android-4.2.2_r1"),
array("sdk" => 18, "name" => "Jelly Bean MR2", "dir" => "/mnt/androidos/android-4.3_r1"),
array("sdk" => 19, "name" => "Kitkat", "dir" => "/mnt/androidos/android-4.4.4_r1"),
array("sdk" => 20, "name" => "Kitkat Watch", "dir" => "/mnt/androidos/android-4.4w_r1"),
array("sdk" => 21, "name" => "Lollipop", "dir" => "/mnt/androidos/android-5.0.1_r1"),
array("sdk" => 22, "name" => "Lollipop MR1", "dir" => "/mnt/androidos/android-5.1.0_r3"),
array("sdk" => 23, "name" => "Marshmallow", "dir" => "/mnt/androidos/android-6.0.1_r16"),
);
}
public function getAll(){
return $this->androidOsConfig;
}
public function getOsInfo($sdk){
foreach($this->androidOsConfig as $configItem){
if($configItem["sdk"] == $sdk){
return $configItem;
}
}
return null;
}
public function getSdkName($sdk){
foreach($this->androidOsConfig as $configItem){
if($configItem["sdk"] == $sdk){
return $configItem["name"];
}
}
return "";
}
public function getSdkPath($sdk){
foreach($this->androidOsConfig as $configItem){
if($configItem["sdk"] == $sdk){
return $configItem["dir"];
}
}
return "";
}
}
为了支持简单的按文件名搜索代码的功能,需要数据库支持。实现方式为事先将所有文件,文件所在目录(相对目录)及OS版本添加到数据库中,当用户输入文件名时,直接通过sql语句的like功能搜索文件名字段。当然,like本身效率低下,需要给文件名字段(filename)建立索引。
如果不需要搜索功能,则可以不用数据库支持。
表android_os_search表结构如下所示:
DROP TABLE IF EXISTS `android_os_search`;
CREATE TABLE `android_os_search` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`filename` varchar(512) DEFAULT '',
`filepath` text,
`os` int(11) DEFAULT '0' COMMENT 'Android的OS版本号,如8=Froto',
`status` int(11) DEFAULT '1',
`create_time` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '加入时间',
`update_time` timestamp NOT NULL DEFAULT '1999-01-01 01:01:01' COMMENT '修改时间',
PRIMARY KEY (`id`),
KEY `filename_index` (`filename`(255))
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
为了更好的源代码阅读体验,欢迎体验Android OS在线源代码
Copyright© 2013-2020
All Rights Reserved 京ICP备2023019179号-8