Skip to content

wangfakang/yaf-1

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

45 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

#购物车 yaf+opcache for mvc+orm to api

可以当作学习yaf的入门项目,讲解比较细

DEMO: http://cartbyyaf.sinaapp.com/

##涉及技术 ####前端

  • requirejs:模块化和异步加载
  • bootstrap,yeti:响应式框架,支持手机访问,yeti主题
  • forp:页面响应性能,访问index_forp.php

####后端

  • smarty/twig:php模板引擎,默认关闭
  • memcached:kv快速存取,默认关闭
  • medoo:orm数据库半框架,library/Db.php

##快速开始

可以按照以下步骤来部署和运行程序(SAE已经内置,不需要自己安装):

1.请确保机器localhost已经安装了Yaf扩展框架, 并且已经启动服务器和PHP;
2.把这个项目拷贝到Webserver的DocumentRoot目录下;
3.创建php.d/yaf.ini文件,里面启用如下配置,代码才能正确运行:
    extension=yaf.so
4.导入schema.sql,并确保conf/application.ini中,mysql的host,user,pwd正确配置.
5.重启Webserver;
6.访问http://yourhost/,出现网站页面!, 表示运行成功,否则请查看错误日志;

yaf.ini文件详细说明:

[yaf]
extension=yaf.so
yaf.environ = product
yaf.library = NULL
yaf.cache_config = 0
yaf.name_suffix = 1
yaf.name_separator = ""
yaf.forward_limit = 5
yaf.use_namespace = 0     // 如果使用类,可以开启
yaf.use_spl_autoload = 0  // 冒泡获取自动加载器

###目录结构

对于Yaf的应用, 都应该遵循类似下面的目录结构.

本项目的目录说明

+ public
  |- index.php //入口文件
  |- index_forp.php //性能测试入库
  |- .htaccess //重写规则
  |- favicon.jpg
  |+ css
  |+ images
  |+ js
+ conf
  |- application.ini //配置文件
+ application
  |+ controllers
     |- Index.php //默认控制器
  |+ views    
     |+ index   //控制器
     |- index.phtml //默认视图
  |- Bootstrap.php //项目的全局配置,包括路由和memcached的配置等
  |- yaf_classes.php //yaf框架的函数列表,方便补全
+ modules //其他模块
+ library //本地类库
+ models  //model目录
+ plugins //插件目录
+ tests   //测试目录
+ globals   //插件目录和全局配置
  |+ cache  //模板生成的缓存文件
  |+ composer         //composer下载的lib
     |- composer.json //composer的依赖配置

###重写规则

除非我们使用基于query string的路由协议(Yaf_Route_Simple, Yaf_Route_Supervar), 否则我们就需要使用WebServer提供的Rewrite规则, 把所有这个应用的请求, 都定向到上面提到的入口文件.

####Apache的Rewrite (httpd.conf) .htaccess

RewriteEngine On
RewriteCond %{REQUEST_FILENAME} !-f
RewriteRule .* index.php

当然也可以写在httpd.conf[option]

DocumentRoot "path/public" #需要定位到本项目的public文件夹
<Directory "path/public">
    RewriteEngine On
    RewriteCond %{REQUEST_FILENAME} !-f
    RewriteRule .* index.php
</Directory>

####Nginx的Rewrite (nginx.conf)

root path/public #需要定位到本项目的public文件夹
location / {
    try_files $uri $uri/ /index.php;
}

####Lighttpd的Rewrite (lighttpd.conf)

$HTTP["host"] =~ "(www.)?domain.com$" {
  url.rewrite = (
     "^/(.+)/?$"  => "/index.php/$1",
  )
}

####SAE的Rewrite (config.yaml)

name: your_app_name
version: 1
handle:
    - rewrite: if(path ~ "^(?!public/)(.*)") goto "/public/$1"
    - rewrite: if(!is_file()) goto "/public/index.php"

或者在SAE面板 appconfig->rewrite->高级设置->直接在大框框下填入下面的内容->保存

    - rewrite: if(path ~ "^(?!public/)(.*)") goto "/public/$1"
    - rewrite: if(!is_file()) goto "/public/index.php"

[注意] 每种Server要启用Rewrite都需要特别设置, 如果对此有疑问.. RTFM

[注意] 使用opcache的时候,它会缓存php为静态,debug的时候,最好关闭

LAMP实践

# 在CentOS6-7测试过
yum install httpd mysql php php-mysql php-pear
pear install yaf
git clone http://github.com/yantze/yaf /var/www/html/shop

# 先创建一个用户名为shop,密码为shop,可以管理shop数据库的账户
mysql -ushop -p shop < schema.sql

echo '; Enable yaf extension module
extension=yaf.so
yaf.environ="product"
;yaf.environ="devel"
;yaf.use_namespace = 1
yaf.cache_config = 1
yaf.use_spl_autoload = 0
' > /etc/php.d/yaf.ini

echo 'Listen 85
<VirtualHost *:85>
	ServerName localhost
	DocumentRoot "/var/www/html/shop/public"

	ErrorLog logs/test_error_log
	LogLevel warn
	CustomLog logs/test_access_log combined
</VirtualHost>

<Directory "/var/www/html/shop/public">
    AllowOverride ALL
    Options Indexes FollowSymLinks
    Order allow,deny
    Allow from all
</Directory>' >> /etc/httpd/conf/httpd.conf

service httpd restart
# 在浏览器访问http://webserver:85/,就可以看到网站部署成功

参考

yaf的一些资源:http://www.laruence.com/2012/07/06/2649.html

yaf学习的一些思路:http://achun.iteye.com/blog/1473126

YafUse项目给了我很大的帮助:https://www.github.com/melonwool/YafUse/

yaf的api:http://yaf.laruence.com/manual/index.html

数据库设计上面主要有课本上的一些知识

浅谈数据库设计技巧:http://www.knowsky.com/4937.html

SAE:sina app engine

最终效果: home backpabe

About

使用yaf做的购物网站yar+msgpack+opcache for mvc+orm to api

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • PHP 42.8%
  • CSS 33.3%
  • JavaScript 12.0%
  • HTML 11.6%
  • Other 0.3%