使用工具
- 使用git的命令行工具或者
cmder
- 注意使用
cmd
命令行是不行的,cmd
命令行并不能识别openssl
命令
openssl genrsa 命令介绍
openssl genrsa
命令是会用来生成 RSA 私有秘钥,不会生成公钥,因为公钥提取自私钥。生成时是可以指定私钥长度和密码保护。
如果需要查看公钥或生成公钥,可以使用 openssl rsa
命令。
创建私钥
生成秘钥是生成证书的前提
小峰的博客
废话不多说直接上车
1 | DROP TABLE IF EXISTS `region`; |
/common/models/Region.php
需求:假设我们有一张商品表goods和一张商品分类表categories,通过商品分类简称搜索商品列表
goods表AR
1 | namespace common\models; |
Yii2框架下展示列表数据通常用Gridview
来实现,这里整理常用的小技巧,方便以后查询使用
1 | <?= GridView::widget([ |
单数行为绿色背景,偶数行为红色背景
1 | <?= GridView::widget([ |
red
和green
需要有对应的样式实现
如果在view中直接添加js代码,如下:
1 | <script> |
会提示没有$ is not defined
错误,这是因为view中添加js代码的前面没有引用juqery.js,默认全局的jquery则是在文件尾添加。
解决方法:
Order
模型
1 | class Order extends \yii\db\ActiveRecord |
OrderItem
模型是 Order
与 Item
的中间表
order
表的主键 id
与 order-item
表 order_id
关联
item
表的主键 id
与 order-item
表 order_id
关联
通过Order模型获取关联的Item表数据
1 | $order = Order::find()->all(); |
使用 timeStampBehavior
这个行为支持在 Active Record
存储时自动更新它的时间戳属性
1 | namespace app\models\User; |
以上指定的行为数组:
当记录插入($model->insert()
或$model->save()
)时,行为将当前时间戳赋值给 created_at
和 updated_at
属性;
当记录更新($model->update()
)时,行为将当前时间戳赋值给 updated_at
属性。
使用
$model->save()
更新数据updated_at
不更新
如果更新字段数据没有改变$model->update()
返回0
TimestampBehavior
行为还提供了一个有用的方法 touch()
, 这个方法能将当前时间戳赋值给指定属性并保存到数据库:
1 | $user->touch('login_time'); |
1 | User::find()->all(); // 返回所有数据; |
单位以前服务器代码更新使用的是FTP上传,这样无法保证服务器代码和仓库代码保持一致,忍不了了,果断改成git拉取
第一步,有代码的管理仓库
第二步,拉取服务器的代码到本地,然后再提交到代码仓库,保持当前服务器和代码库文件和文件内容一致
第三步,在服务器上安装git,并生成公钥
1 | # ssh-keygen -t rsa |
第四步,把服务器的公钥配置到代码库的部署公钥管理中
第五步,在服务器上代码根目录初始化git