非常好用的两个PHP函数 serialize()和unserialize()

今天,在做一个关于PING服务的东西,由于不想把ping服务地址放进数据库中,那样不好,ping服务本来不是一个效率不高的事,再放进数据库中,不但更加降低了程序的效率,还给服务器带来不必要的损耗,所以,想办法所ping服务地址用数组的方式放进了.conf文件中,才开始的设计思路是通过生成的php代码放到.php文件中,然后再把.php文件载入进来,后来,发现操作起来不太方便,所以,决定使用serialize()函数和unserialize()函数,这两个函数的用法真是绝配,一个是进行序列化存储,另一个则是进行序列化恢复,方便极了,函数用法代码分享:

<?php 
$array =[]; 
$array['key'] = 'website'; 
$array['value']='www.ljwit.com' 
$a = serialize($array); 
echo $a; 
unset($array); 
$a = unserialize($a); 
print_r($a); 
?> 

没有写太具体的用法,童鞋可以自己思考,然后尝试,还是那句话,我这里说的只是一种思路和方法,具体用法,还是要自己研究。

github提交代码、更新代码方法[详解]

第一:先说首次使用 意思就是这个文件夹中的代码你还没有向GITHUB提交过代码

cd /home/test(假如 test就是你的用户名)/githubtest(这是个文件夹,你可以提前先建立好,这个文件夹也可以是你要提交代码的项目文件夹)

git init //这是初始化在这个文件夹中建立一个空库

git add  //这个命令 你可以直接  git add . 这是把当前文件夹中的所有文件都加入到上传的列表中(注意要有空格),你还可以添加具体的文件 git add 你要添加的文件(test/test/test.txt)

git commit -m “说明”   //这个 说明 以你自己随意(注意要加 双引号),还要注意 这个条命令最好这样写,网上的有文章说 只用 git commit 这样不是不可以 这样是可以   这样的命令 系统会自动用一个 默认的应用程序打开一个文件让你输入  说明   ,但如果系统没有默认打开的话那就不能继续往下执行了,反正都是要写 说明  ,本来也没几个字,建议大家 直接 把命令写全,省的给自己找麻烦

git remote add origin https://github.com/test/testt.git  //这里说两处地方  origin 这个相当于是个别名  你可以自己随便写也可以写成当前文件夹的名 , 后面的地址是你在GITHUB 刚刚新建的 库 地址, 你建了哪几个库,你到GITHUB找到 你 建的库点进去 就能看到相应的地址.

git push -u origin master    //开始上传了  ,然后 会提示你 输入 你在 GITHUB上注册的用户名跟密码 输入正确后就等着上传吧

第二:下面说说更新代码的操作吧

cd /home/test(假如 test就是你的用户名)/githubtest(这个文件夹是你要提交代码的项目文件夹,前提是你已经用过第一种方法了)

git add .     或者添加具体的文件 git add 你要添加的文件(test/test/test.txt)

git commit -m “说明”

git push -u origin master     //还记的这个别名吗  origin  这个别名就是你用第一种方法首次 向 GITHUB提交代码 你用的 别名

好了  这就是使用GITHUB 提交自己的代码 操作了.大家可以举一反三的 自己去思考,其它更多的功能大家就自己去挖掘吧

[laravel]laravel5.2数据库手动操作事物示例

如果你想要手动开始事务从而对回滚和提交有一个完整的控制,可以使用DB门面的beginTransaction方法:

DB::beginTransaction();

你可以通过rollBack方法回滚事务:

DB::rollBack();

最后,你可以通过commit方法提交事务:

DB::commit();

测试代码:

DB::beginTransaction();
		DB::table('user')->where('user_id',1)->update(['user_pass' => '123456']);
		$db=DB::table('user')->where('user_id',1)->update(['user_pass' => '123456']);
		if($db){
			DB::commit();
			echo '提交事务';
		}else{
			DB::rollBack();
			echo '回滚事务';
		}

[laravel]laravel5.2正则路由以及全局正则路由参数过滤

laravel路由功能非常强大,可以通过正则限定路由参数类型,也可以设置全局参数进行设置。

Route::get('user/{name}', function ($name) {
    //
})
->where('name', '[A-Za-z]+');

Route::get('user/{id}', function ($id) {
    //
})
->where('id', '[0-9]+');

Route::get('user/{id}/{name}', function ($id, $name) {
    //
})
->where(['id' => '[0-9]+', 'name' => '[a-z]+']);

还可以直接在routeserviceprovider启动方法定义,可以起到全局限制作用

qq%e4%ba%94%e7%ac%94%e6%88%aa%e5%9b%be%e6%9c%aa%e5%91%bd%e5%90%8d

[laravel]nginx配置laravel路由方法

为了让nginx支持laravel的路由,必须将nginx.conf 的server段设置成如下样式:

server {
 listen 80; 
 server_name sub.domain.com; 
 set $root_path 'd:/wwwweb/mysite/vblog/public'; 
 root $root_path; 

 index index.php index.html index.htm; 

 try_files $uri $uri/ @rewrite; 

 location @rewrite { 
 rewrite ^/(.*)$ /index.php?_url=/$1; 
 } 

 location ~ \.php { 

 fastcgi_pass 127.0.0.1:9000; 
 fastcgi_index /index.php; 

 fastcgi_split_path_info ^(.+\.php)(/.+)$; 
 fastcgi_param PATH_INFO $fastcgi_path_info; 
 fastcgi_param PATH_TRANSLATED $document_root$fastcgi_path_info; 
 fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; 
 include fastcgi_params;
 } 

 location ~* ^/(css|img|js|flv|swf|download)/(.+)$ { 
 root $root_path; 
 } 

 location ~ /\.ht { 
 deny all; 
 } 
 }

[laravel]Laravel5.2目录结构及composer.json文件解析

Laravel5.2目录结构及composer.json文件解析	
	
目录或文件	说明
|– app	包含Controller、Model、路由等在内的应用目录,大部分业务将在该目录下进行
|  |– Console	命令行程序目录
|  |  |– Commands	包含了用于命令行执行的类,可在该目录下自定义类
|  |  |– Kernel.php	命令调用内核文件,包含commands变量(命令清单,自定义的命令需加入到这里)和schedule方法(用于任务调度,即定时任务)
|  |– Events	事件目录
|  |– Exceptions	包含了自定义错误和异常处理类
|  |– Http	HTTP传输层相关的类目录
|  |  |– Controllers	控制器目录
|  |  |– Middleware	中间件目录
|  |  |– Requests	请求类目录
|  |  |– Kernel.php	包含http中间件和路由中间件的内核文件
|  |  |– routes.php	强大的路由
|  |– Jobs	该目录下包含队列的任务类
|  |– Listeners	监听器目录
|  |– Providers	服务提供者目录
|  |– User.php	自带的模型实例,我们新建的Model默认也存储在该目录
|– bootstrap	框架启动载入目录
|  |– app.php	创建框架应用实例
|  |– autoload.php	自动加载
|  |– cache	存放框架启动缓存,web服务器需要有该目录的写入权限
|– config	各种配置文件的目录
|  |– app.php	系统级配置文件
|  |– auth.php	用户身份认证配置文件,指定好table和model就可以很方便地用身份认证功能了
|  |– broadcasting.php	事件广播配置文件
|  |– cache.php	缓存配置文件
|  |– compile.php	编译额外文件和类需要的配置文件,一般用户很少用到
|  |– database.php	数据库配置文件
|  |– filesystems.php	文件系统配置文件,这里可以配置云存储参数
|  |– mail.php	电子邮件配置文件
|  |– queue.php	消息队列配置文件
|  |– services.php	可存放第三方服务的配置信息
|  |– session.php	配置session的存储方式、生命周期等信息
|  |– view.php	模板文件配置文件,包含模板目录和编译目录等
|– database	数据库相关目录
|  |– factories	5.1以上版本的新特性,工厂类目录,也是用于数据填充
|  |  |– ModelFactory.php	在该文件可定义不同Model所需填充的数据类型
|  |– migrations	存储数据库迁移文件
|  |– seeds	存放数据填充类的目录
|     |– DatabaseSeeder.php	执行php artisan db:seed命令将会调用该类的run方法。该方法可调用执行该目录下其他Seeder类,也可调用factories方法生成ModelFactory里定义的数据模型
|– public	网站入口,应当将ip或域名指向该目录而不是根目录。可供外部访问的css、js和图片等资源皆放置于此
|  |– index.php	入口文件
|  |– .htaccess	Apache服务器用该文件重写URL
|  |– web.config	IIS服务器用该文件重写URL
|– resources	资源文件目录
|  |– assets	可存放包含LESS、SASS、CoffeeScript在内的原始资源文件
|  |– lang	本地化文件目录
|  |– views	视图文件就放在这啦
|– storage	存储目录。web服务器需要有该目录及所有子目录的写入权限
|  |– app	可用于存储应用程序所需的一些文件
|  |– framework	该目录下包括缓存、sessions和编译后的视图文件
|  |– logs	日志目录
|– tests	测试目录
|– vendor	该目录下包含Laravel源代码和第三方依赖包
|– .env	环境配置文件。config目录下的配置文件会使用该文件里面的参数,不同生产环境使用不同的.env文件即可。
|– artisan	强大的命令行接口,你可以在app/Console/Commands下编写自定义命令
|– composer.json	存放依赖关系的文件
|– composer.lock	锁文件,存放安装时依赖包的真实版本
|– gulpfile.js	gulp(一种前端构建工具)配置文件
|– package.json	gulp配置文件
|– phpspec.yml	phpspec(一种PHP测试框架)配置文件
|– phpunit.xml	phpunit(一种PHP测试框架)配置文件
|– server.php	PHP内置的Web服务器将把这个文件作为入口。以public/index.php为入口的可以忽略掉该文件
	
	
	
composer.json文件	
{	
    "name": "laravel/laravel",	//项目名称
    "description": "The Laravel Framework.",	//描述
    "keywords": ["framework", "laravel"],	//关键词
    "license": "MIT",	//许可协议
    "type": "project",	//类型
    "require": {	
        "php": ">=5.5.9",	//PHP版本
        "laravel/framework": "5.2.*"	//框架版本
    },	
    "require-dev": {	//依赖包
        "fzaninotto/faker": "~1.4",	
        "mockery/mockery": "0.9.*",	
        "phpunit/phpunit": "~4.0",	
        "symfony/css-selector": "2.8.*|3.0.*",	
        "symfony/dom-crawler": "2.8.*|3.0.*"	
    },	
    "autoload": {	//自动加载
        "classmap": [	
            "database"	
        ],	
        "psr-4": {	//一种自动加载的规范
            "App\\": "app/"	
        }	
    },	
    "autoload-dev": {	//加载测试
        "classmap": [	
            "tests/TestCase.php"	
        ]	
    },	
    "scripts": {	//执行脚本
        "post-root-package-install": [	
            "php -r \"copy('.env.example', '.env');\""	
        ],	
        "post-create-project-cmd": [	
            "php artisan key:generate"	
        ],	
        "post-install-cmd": [	
            "php artisan clear-compiled",	
            "php artisan optimize"	
        ],	
        "post-update-cmd": [	
            "php artisan clear-compiled",	
            "php artisan optimize"	
        ]	
    },	
    "config": {	//配置项
        "preferred-install": "dist"	//优先安装压缩版
    },	
    "repositories": {	//配置composer镜像
        "packagist": {	
            "type": "composer",	
            "url": "https://packagist.phpcomposer.com"	
        }	
    }	
}	
	
	

[YII]使用归档文件安装yii2.0框架

yii官网网站也有说明,一共俩种安装方式,一是通过composer安装,这个安装方式有时候下载速度较慢,可能还得翻墙,所以我这里说下怎么直接使用归档文件进行安装,也就是直接下载源码使用。

下载地址:http://www.yiichina.com/download

qq%e4%ba%94%e7%ac%94%e6%88%aa%e5%9b%be%e6%9c%aa%e5%91%bd%e5%90%8d

 

 

 

 

我这里下载得是基础版本,然后解压放到我们得web目录下,

最后修改 config/web.php 文件,给 cookieValidationKey 配置项 添加一个密钥(若你通过 Composer 安装,则此步骤会自动完成):

// !!! 在下面插入一段密钥(若为空) - 以供 cookie validation 的需要
'cookieValidationKey' => '在此处输入你的密钥',

这个密匙主要是给cookie加密使用得,大家随便填写,不要是中文即可。

最后配置下本地web服务器,指定web目录

qq%e4%ba%94%e7%ac%94%e6%88%aa%e5%9b%be%e6%9c%aa%e5%91%bd%e5%90%8d

 

 

 

直接访问即可。

qq%e4%ba%94%e7%ac%94%e6%88%aa%e5%9b%be%e6%9c%aa%e5%91%bd%e5%90%8d

windows下安装redis扩展

本文介绍下在windows环境怎么给php安装redis扩展

1.使用phpinfo()函数查看PHP的版本信息,这会决定扩展文件版本

这里主要要看俩个信息

第一就是当前php版本,我这里是5.5
22

 

 

 

然后一个信息就是,当前php版本是ts还是nts

qq%e4%ba%94%e7%ac%94%e6%88%aa%e5%9b%be%e6%9c%aa%e5%91%bd%e5%90%8d

 

 

 

2.根据PHP版本号,编译器版本号和CPU架构,选择合适版本

下载地址:

http://windows.php.net/downloads/pecl/snaps/redis/2.2.5/

http://windows.php.net/downloads/pecl/releases/igbinary/1.2.1/

3.解压缩后,将php_redis.dll和php_igbinary.dll拷贝至php的ext目录下

4.修改php.ini

extension=php_igbinary.dll

extension=php_redis.dll

注意:extension=php_igbinary.dll一定要放在extension=php_redis.dll的前面,否则此扩展不会生效

最后重启服务再次运行下phpinfo,可以看到redis已经安装成功,

qq%e4%ba%94%e7%ac%94%e6%88%aa%e5%9b%be%e6%9c%aa%e5%91%bd%e5%90%8d