> 一. URL 路由
WeCenter 有一个解析能力强大的 URL 路由
**1. 动作访问:**
* * * * *
/模块名/控制器/动作/ID
ID 为 id 查询, 例: `account/login/123`, 则在 login 控制器中 `$_GET[‘id’] `的值为 123
(*) 如果使用 /模块名/控制器/动作/ID 格式 Query string 的使用可以参照 兼容性的支持
(*) 如果动作在 main 控制器中可以省略, 例: `account/main/login/ `等同于 `account/login/`
(*) 如果动作名为 index 可以省略, 例: `account/login/index/ `等同于 `account/login/`
**2. Query string**
* * * * *
WeCenter 的查询字符串为使用 __ 分隔参数, 使用 – 为参数赋值, 在程序中直接使用 $_GET 取出内容
常规的: `account/login/?return_url=1&callback=2`
WeCenter 的: `account/login/return_url-1__callback-2`
(*) 在程序中输出 URL 请使用 get_js_url 函数, 因为这样会兼容 Rewrite 是否开启两种情况
**3. 兼容性的支持**
* * * * *
下面的几种 URL 形式在程序中都是被支持的:
~~~
http://domian/index.php?/question/id-320__column-log__source-doc
http://domian/index.php?/question/320?column=log&source=doc
http://domian/index.php?/question/?id=320&column=log&source=doc
http://domian/index.php?/question/320?column-log__source-doc
http://domian/index.php?/question/320&column-log__source-doc
~~~
> 二. 模板命名规则
程序中所有模板的存放规则为 模块/控制器/动作, 如果控制器为 main 则省略
如 `account/main/login/ `对应的模板为 views/模板集`/account/login.tpl.htm`
如 `account/setting/profile/` 对应的模板为 views/模板集`/account/setting/profile.tpl.htm`
> 三. 自动引入机制
WeCenter 类库, Model 的使用都是不需要事先引入文件的, 这使得在编程过程中变得方便快捷, 也避免了类库重复实例化的问题, 但是使用自动引入机制需要遵循下面的规则.
(*) 所有自动引入的类库都不需要事先实例化, 直接使用即可.
**1. Model**
* * * * *
放在 model 目录下, 文件名: name.inc.php
文件中需要有继承 AWS_MODEL 的 name_class
(*) 在程序中使用方法: $this->model(‘name’)->action();
(*) 可用范围: CONTROLLER, Model
**2. System 类库**
* * * * *
放在 system 目录之下, 类名相对于 system 目录, 将 / 换成 _
例: Zend_Mail
路径: system/Zend/Mail.php
类名: Zend_Mail
(*) 在程序中使用方法: new, 静态调用, load_class(‘class_name’);
(*) 可用范围: 任意, 不需要带参数实例化建议使用 load_class
**3. 配置文件**
* * * * *
放在 system/config 目录之下, 文件内容为一个 $config 数组, 命名为 配置名.php
(*) 在程序中使用方法: AWS_APP::config()->get(‘配置名’)->数组下标
(*) 可用范围: 任意, 不需要带参数实例化建议使用 load_class
**四. 模板机制**
* * * * *
WeCenter 的模板采用继承机制, 系统的 default 为主模板, 用户的自定义模板只需要更改很少的文件即可实现程序界面的定制.
继承机制原理:
~~~
当管理员设定了一个 newstyle 模板, 用户访问首页
⬇
系统开始查找 views/newstyle/home/index.tpl.htm
⬇
找到相应文件 找不到文件
⬇ ⬇
读取内容并
解析后显示 ⬅ 读取 views/default/home/index.tpl.htm
~~~
建立模板集的方法:
1. 在 views 下面建立模板集目录
2. 在 static/css/ 下建立与模板集相同的目录, 我们建议从 static/css/default/ 拷贝一份内容到新建的模板集中, 然后开始修改工作.
> 五. 常用开发指导
**JavaScript:**
* * * * *
我们使用 jQuery 作为主要 framework, 载入的插件有:
jQuery Form ( http://malsup.com/jquery/form/ )
AJAX Upload ( http://valums.com/ajax-upload/ )
Valums file Uploader (修改过)
**jQuery.ScrollTo**
* * * * *
(*) 在 Javascript 中判断用户是否登录判断全局变量 G_USER_ID 是否大于 0 即可
(*) 全局变量在 header 模板中
(*) 所有 JS 请求 URL 需要加上 G_BASE_URL 前缀
(*) 全局 ajax 列表函数使用 bp_load_more
**PHP:**
* * * * *
关于 Zend Framwork 类库的使用方法请参考官方文档
(*) 在控制器中判断用户是否登录判断 $this->user_id 是否大于 0 即可
(*) 控制器与模板中始终可用 $this->user_id 和 $this->user_info
(*) 控制器与 Model 中禁止使用构造函数, 可以用 setup() 函数替代
(*) 程序已经提供了两个中文处理函数 cjk_substr 和 cjk_strlen
**Access Rule:**
* * * * *
~~~
public function get_access_rule()
{
// 规则类型
// white: actions 里的 action 全部用户可见, 其余 action 需要登录
// black: actions 里的 action 需要登录, 其余 action 全部用户可见
$rule_action[“rule_type”] = ‘white';
$rule_action[“actions”] = array(
‘check_username’,
‘check_email’,
‘register_process’,
‘login_process’,
‘register_agreement’,
‘send_valid_mail’,
‘valid_email_active’,
‘request_find_password’,
‘find_password_modify’
);
return $rule_action;
}
~~~
(*) 控制器中不加此函数, 则所有 action 必需登录可见
模板:
(*) 在模板可以使用 PHP 代码, 全部静态类与 function, 但是不能使用 Model
(*) 模板中 $this-> 中的内容是全局通用变量, 可以在模板中引入的模板使用, 模板内部产生的变量则不能
> 六. 常用开发方法使用
**1、TPL::assign()模板赋值 **
* * * * *
~~~
语法:TPL::assign($name, $value)
说明:$name,变量的名字,不需要加$。$value,是具体各种类型的值。
使用范例: TPL::assign('name', 'WeCenter') 返回结果为:直接在模板里echo $name;就会显示值
~~~
**2、TPL::set_meta()设置html的meta值(比如:关键词,描述) **
* * * * *
~~~
语法:TPL::set_meta($tag, $value)
说明:$tag,为:keywords关键词,description描述。$value,是具体字符串类型的值。
使用范例: TPL::set_meta('keywords', 'WeCenter'); 返回结果为:直接在模板里$this->_meta_description;就会显示值
~~~
**3、TPL::output()模板渲染 **
* * * * *
~~~
语法:TPL::output($template_filename, $display = true)
说明:$template_filename,为模板名字,不需要带后缀。$display,是输出还是赋值变量。
使用范例: TPL::output('article/index'); 返回结果为:渲染article下面index.tpl.htm模板
~~~
**4、TPL::is_output()判断模板中是否存在某一模板 **
* * * * *
~~~
语法:TPL::is_output($output_filename, $template_filename)
说明:$output_filename,要查询的模板,需要带后缀。$template_filename,被查询的模板。
使用范例: TPL::is_output('block/sidebar_hot_topics.tpl.htm', 'article/square'); 返回结果为:true or false
~~~
**5、H::ajax_json_output() ajax返回 **
* * * * *
~~~
语法:H::ajax_json_output($array)
说明:$array,返回的数组。
使用范例: H::ajax_json_output(AWS_APP::RSM(null, '-1', AWS_APP::lang()->_t('请输入回复内容')));返回结果为:json格式的
~~~
**6、AWS_APP::lang() 语言转换 **
* * * * *
~~~
语法:AWS_APP::lang()->_t('要转换的词');要在 language文件的php文件里找到对应的键值
说明:$array,返回的数组。
使用范例: AWS_APP::lang()->_t('注册失败'); 返回结果为:注册失败
~~~
- 快速开始
- 系统介绍
- 下载源码
- 入口文件
- MVC模式
- 控制器
- 基础
- 安装
- 开发规范
- 目录结构
- 配置
- 配置格式
- 配置加载
- 读取配置
- 动态配置
- 架构
- 架构总览
- 控制器
- 模型
- 视图
- 插件开发
- 数据库
- aws_active_data(邮箱验证以及找回密码记录表)
- aws_answer (回答)
- aws_answer_comments (回答评论表)
- aws_answer_thanks (回答感谢表)
- aws_answer_uninterested (回答没有帮助表)
- aws_answer_vote(回答点赞、反对表)
- aws_approval (审核用户发布内容表)
- aws_article(文章表)
- aws_article_comments(文章评论表)
- aws_article_vote(文章和文章评论点赞记录表)
- aws_attach(附件表)
- aws_category(分类表)
- aws_draft(各种草稿的数据表)
- aws_edm_task(邮件群发管理表)
- aws_edm_taskdata(edm任务邮件列表)
- aws_edm_unsubscription(edm退订邮件订阅表)
- aws_edm_userdata(edm群发邮件,用户邮件表)
- aws_edm_usergroup(edm邮件用户群组表)
- aws_education_experience(教育经历)
- aws_favorite(用户收藏表)
- aws_favorite_tag(收藏tag表)
- aws_feature(专题表)
- aws_feature_topic(专题相关话题)
- aws_geo_location(用于附近的人以及附件问题的经度纬度记录表)
- aws_help_chapter(帮助表)
- aws_inbox(私信表)
- aws_inbox_dialog(私信详细记录表)
- aws_integral_log(用户积分操作记录表)
- aws_invitation(用户邀请注册表)
- aws_jobs(职位表)
- aws_mail_queue(发送邮件排队表)
- aws_nav_menu(导航栏表)
- aws_notification (系统通知)
- aws_notification_data(系统通知数据表)
- aws_pages(单页面表)
- aws_payment(支付表)
- aws_posts_index(首页推荐表)
- aws_product_order(众筹产品支付表)
- aws_project(众筹表)
- aws_project_like(众筹喜欢表)
- aws_project_product(众筹产品表)
- aws_question(问题列表)
- aws_question_comments(问题评论表)
- aws_question_focus(问题关注表)
- aws_question_invite(邀请问答)
- aws_question_thanks(问题感谢表)
- aws_question_uninterested(问题不感兴趣表)
- aws_received_email(已导入邮件列表)
- aws_receiving_email_config(邮件账号列表)
- aws_redirect(重定向表)
- aws_related_links(相关链接)
- aws_related_topic(相关话题)
- aws_report(用户举报表)
- aws_reputation_category(文章威望记录表)
- aws_reputation_topic(话题威望表)
- aws_school(学校)
- aws_search_cache(搜索缓存表)
- aws_sessions(session表)
- aws_system_setting(系统设置)
- aws_ticket(工单表)
- aws_ticket_invite(工单邀请表)
- aws_ticket_log(工单记录表)
- aws_ticket_reply(工单回复表)
- aws_topic(话题)
- aws_topic_focus(话题关注表)
- aws_topic_merge(话题合并表)
- aws_topic_relation(话题相关问题或者文章表)
- aws_user_action_history(用户操作记录)
- aws_user_action_history_data(用户操作内容记录表)
- aws_user_action_history_fresh(用户刷新记录表)
- aws_user_follow(用户关注表)
- aws_users(用户表)
- aws_users_attrib(用户附加属性表)
- aws_users_facebook (facebook表)
- aws_users_google (用户谷歌表)
- aws_users_group(用户组)
- aws_users_notification_setting(通知设定)
- aws_users_online(在线用户列表)
- aws_users_qq(qq登录用户表)
- aws_users_sina(微博登录表)
- aws_users_twitter (twitter登录)
- aws_users_ucenter(ucenter登录表)
- aws_users_weixin(微信登录表)
- aws_verify_apply (认证申请表)
- aws_weibo_msg(新浪微博消息列表)
- aws_weixin_accounts (微信多账号设置)
- aws_weixin_login (WeCenter 自己的微信登录体系表 )
- aws_weixin_message (用户给公众号发送的消息)
- aws_weixin_msg (微信群发列表)
- aws_weixin_qr_code(微信二维码)
- aws_weixin_reply_rule (微信自定义回复表)
- aws_weixin_third_party_api (微信第三方接入)
- aws_work_experience (工作经历)
- 常见问题
- 安装和设置
- 前台手册
- 后台手册
- 附录
- 系统函数
- 开发范例
- 更新日志