- 浏览: 106559 次
- 性别:
- 来自: 深圳
-
文章分类
最新评论
-
沉醉音乐的咖啡:
引用
Yii框架中ActiveRecord使用Relations -
stevecj:
呵呵,这个以后再交流。
盛大开始行动了,值得尊敬 -
庄表伟:
谢谢鼓励!我们会更加努力的。能聊聊你想做的另一个新产品是什么吗 ...
盛大开始行动了,值得尊敬
db组件 'schemaCachingDuration'=>3600, 为什么不起做用?
需要开缓存
如何在页面下边显示sql的查询时间
在log组件的routes中加入
array(
'class'=>'CProfileLogRoute',
'levels'=>'error, warning',
)
同时在db组件中加入
'enableProfiling'=>true,
同时在这种情况下,可以用CDbConnection::getStats() 查看执行了多少个语句,用了多少时间
如何知道某一个程序段运行需要的时间
配置好CProfileLogRoute后,在需要测试的地方加上
Yii::beginProfile('blockID');
//程序段
Yii::endProfile('blockID');
'enableParamLogging'=>true,的作用是?
在日志的bind的参数后边跟数的值
如何在页面底部显示所有的db相关的日志
同上,配置log组件的routes中加入
array(
'class'=>'CWebLogRoute',
'levels'=>'trace, info, error, warning',
'categories' => 'system.db.*',
//'showInFireBug' => true, 将在firebug中显示日志
),
把日志记录到数据库
array(
'class'=>'CDbLogRoute',
'logTableName'=>'applog',
'connectionID'=>'db',
),
运行时表applog会自动生成,如果不能生成,参照api自已建立
如何记录$_GET,$_SESSION等信息,在以上的routes中各个配置中加上
'filter'=>'CLogFilter',
log配置中的level设置不对,可能会得不到日志信息
另外level,category的值可以随便写,
只要在用yii::Log("","自定义level","自定义的category")时对应起来即可
如何记录更详细的信息,能记录stack,在入口文件中加上
define('YII_TRACE_LEVEL',10);数字越大,记当的越详细,结果如下
[15:31:57.226][trace][system.db.CDbCommand] Querying SQL: SHOW COLUMNS FROM `Bangdan` in E:\APMServ5.2.6\www\htdocs\dayouhui.com\protected\models\Bangdan.php (21)
in E:\APMServ5.2.6\www\htdocs\dayouhui.com\protected\components\HotBangdan.php (21) in E:\APMServ5.2.6
如果在调试时,终止程序运行且看到日志,不能用die及exit;
用application::end,即Yii::app()->end(),其会触发onEndRequest事件,日志就是在这个事件中记录的
activeRecord几个占位方法重写的注意点
必须带boolean返回值
如何发布一个资源文件并引用
$css=Yii::app()->getAssetManager()->publish(dirname(__FILE__)."/aa.css");
yii::app()->clientScript->registerCssFIle($css);
如果改变activelable中默认的标题
重写方法attributeLabels
过滤不良代码
$purifier=new CHtmlPurifier;
$purifier->options=array("HTML.Allowed"=>"div");
$content=$purifier->purify($content);
或者
<?php $this->beginWidget('CHtmlPurifier'); ?>
...display user-entered content here...
<?php $this->endWidget(); ?>
如何防止重复提交?
提交后
Ccontroler->refresh();
如何在成功后显示一个提示,用户刷新页时去掉提示
Cwebuser->setFlash();
getFlash();
如何防止重复提交, 并在提交成功后给出提示?
控制器中
Yii::app()->user->setFlash('submit','thanks');
$this->refresh();
view中
if(Yii::app()->user->hasFlash('submit')){
echo Yii::app()->user->getFlash('submit');
}
一般我们是跳转到列表页,或用redirect跳到编辑页,就不需要了,如果还是要显示当前页
以上就有用了,比如在当前时显示,编辑或添加新的记录
如何分页
itemCount总记录条数
CPagination代表分页信息,有多少页,每页几条记录等
CLinkPager生成分页的代码,自定义css可以给属性cssFile一个值
$criteria=new CDbCriteria();
$pages=new CPagination("数据库中的总记录数");
$pages->pageSize=2;
$pages->applyLimit($criteria);//给$criteria->limit offset等符值
$posts=Post::model()->findAll($criteria);
$this->widget('CLinkPager',array('pages'=>$pages));
列表如何排序
$criteria=new CDbCriteria();
$sort = new CSort('Post');
$sort->defaultOrder=" status asc";
$sort->applyOrder($criteria);
$posts=Post::model()->findAll($criteria);
应用时用
$sort->link('字段名')
实际是生成一个带参数的url,然后在在applyOrder时应用这些参数修改$criteria,得到相应的查寻结果
如何生成并验证验证码:
基本用法
<?php $this->widget('CCaptcha'); ?> 具体参数查手册
原理CCaptcha这个widget会在run时调用当前控制器的$captchaAction='captcha'方法,这个方法指到一个类CCaptchaAction
其会生成验证码图象,并记入到session中
如何显示静态页
重写actions
'help'=>array(
'class'=>'CViewAction',
'basePath'=>'help', //指定目录名
'defaultView'=>'default',
'viewParam'=>'help' //get参数
),
假定当前控制器是post
那么可以能过/post/help/help/content访问help目录下的content.php
可以建立子目录比如help/reigterhelp/content.那可以通过/post/help/help/registerhelp.content来访问
用CViewAction的好处时,可以与其它的view共享layout
关于没有权限访问跳转的url相关
当没有权限时调用CAccessControlFilter类中的accessDenied,其调用CwebUser中的loginRequired(),记录当前的returnurl后跳转到
CWebUser配置中的loginurl,在此处登陆后,可以通过redirect跳转到returnurl(Yii::app()->request->redirect(Yii::app()->user->returnUrl);)
当强制显示登陆表单,比如判断用户是guest就一直列出登陆表单,不会调用loginRequired, 就得不到returnurl,这时候想跳回去,参见
cookbook上相关贴子
registerCoreScript
在framework/web/js/package.php中列出的才是
多对多关联条件
$criteria->addInCondition("categorys.id",$in);
$criteria->addSearchCondition('Shop.name',$keyword);
$shops=Shop::model()->with(array("categorys"=>array('together'=>true)))->findAll($criteria);
同时要在Shop模型中加入alias="categorys" ,另外together=true放在模型的关联中也可
YII中的RBAC权限,用数据库存item,
在system/web/auth下找到相应的sql导放到数据库中
配置'authManager' => array(
'class' => 'CDbAuthManager',
'connectionID' => 'db',
),
如果在sql中导入的三个表的表名不是默认的,需要在这上边的配置中配置,具体的看api
$auth=Yii::app()->authManager;
//$auth->createOperation("post",'postpost');
//$auth->createTask("post","posts");
$auth->createRole("post","post");
auth->assign("post",'demo');
if(Yii::app()->user->checkAccess("post")){
echo "yes";
else{
echo "no";
}
这种情况下三者是一样的
如何获得上一页的url以返回
Yii::app()->request->urlReferrer;
accessControl 是Ccontroller中内置的过滤方法,其它的还有ajaxOnly postOnly
CMaskedTextField此组件用于限制用户的输入,对应的jquery插件http://digitalbush.com/projects/masked-input-plugin/
在一对多,多对多查询时,the eager loading 联合所有的表生成一条语句,如果主表有limit的查询选项,那么他将单独执行,然后再执行与关联表有关的语句,返回相关表的数据对象,这
就是为什么在做大优惠时,以中间表为查询条件出错的原因,解决办法
with()返回 CActiveFinder对象,其方法together(),既使主表中有LIMIT/OFFSET 也是返回一条sql;
多对多查询时,分页有时候页中显示的条数不正确,因为有重复的项,加上$criteria->group = true即可
模型的rules中,验证某个字段不能重复,array('name', 'unique','message' => '有重复的名子'),
CStatePersister是yii的核心组件,提供了基于文件的数据保存方式,可以不在同的请求中使用
COutputCache 即是一个组件,又是一个filter,前者的时候用于在view中缓存内容,后者的时候用于在controller中缓存
就是说片段缓存,是把COutputCache当一个widget来用,页面缓存把COutputCache当作一个filter来用
动态缓存,用CController的一个方法 renderDynamic($callback);
COutputCache几个属性,duration,dependency
另外还有几个,可以通称为Variation, 有什么作用呢?
在beginCache是需要手工指定一个id,Variation的作有就是自动给生成这个id
在布署模式的时候,有错误不会有stack样的提示,会显示一个errorxxx的错误
如何在程序有错的时候跳到指定的action
在components中设置
'errorHandler'=>array(
'errorAction'=>'site/error',
),
在此action中可以能过Yii::app()->errorHandler->error获得错误信息
把字符串分解成数组,并去掉空值
preg_split('/\s*,\s*/','this , is , , a test',-1,PREG_SPLIT_NO_EMPTY )
CActiveRecord::exits();判断有没有这样的记录,一般用于添加时,判断某字段有没有重复
CActiveDataProvider 一个基于ActiveRecord的数据提供源
常用的用法
$dataProvider=new CActiveDataProvider('Post', array(
'criteria'=>array(),
'pagination'=>array(),
'sort'=>array(),
));
上如'sort'=>array(
'defaultOrder'=>'status, update_time DESC',
),
ClistView同上结合使用,其中的_view中可以用一个$data的变量,代表当前的model数据
如果dataProvider中的pagination,sort设为false,则CliveView中对应的部分也无法使用
$this->widget('zii.widgets.ClistView',array(
'dataProvider' => $dataprovider,
'itemView' => '_view',
'template' => '{items}{sorter}{pager}',
'sortableAttributes' => array(
),
));
CGridView的使用也结合$dataprovider,
用的时候主要是对columns的配置,主要有
CDataColumn, CLinkColumn, CButtonColumn and CCheckBoxColumn.具体用法看api
总的说来CgridView没有ClistView灵活
插入meta信息
Yii::app()->clientScript->registerMetaTag('keywords','关键字');
Yii::app()->clientScript->registerMetaTag('description','一些描述');
CMap::mergeArray() 比array_merge更智能的合并数组,yii中配置的合并用这个
CClipWidget 通过ob_start ob_getconent生成一段不显示的内容,可以能过CController::clips访问,如
$this->beginWidget('CClipWidget',array('id'=>'name','renderClip'=>true));
可以通过$this->clips['name']来显示,其中的renderClip如果为false,则在当前位置不显示内容
如果在Model一次验证多个属于,显示不同的内容?如下 [后来发现这个不起作有]
return array(
array('title, content', 'required',
'message'=>'Please enter a value for {attribute}.'),
// ... other rules
);
获得服务器时间
$_SERVER['REQUEST_TIME']
维护程序时,这样子所有的请求转发到一个地方
'catchAllRequest'=>array('site/all'),
根据二级域名缓存
array(
'COutputCache + search',
'duration' => 120,
'varyByParam' => array('q','page'),
'varyByExpression' => "app()->request->hostInfo",
),
有多个分站时,同步登陆,基于cookie
'user'=>array(
'identityCookie'=>array('domain'=>'.dayouhui.com'),
'allowAutoLogin' => true,
)
如果是基本于session
'session' => array(
'cookieParams' => array('domain' => '.dayouhui', 'lifetime' => 0),
'timeout' => 3600,
),
如何使用theme
在main.php中配置
'theme'=>'classic',
如何得到前前使用的主题
Yii::app()->theme
得到名子
Yii::app()->theme->name;
themes文件夹和protected是同级的,其下边某个theme的目录结果同protected/views下一样
关于skin
用theme改变view的外观,skin是用来改变widgets的外观的
skin是健值对用于初始化一个widget的属性
要对widget使用skin,需要做以下几步
1:配置'widgetFactory'=>array(
'enableSkin'=>true,
),
2:在views下建立skins目录
3:在skins目录下建立与Widget名子一样的php文件,返回数组,即能用于widget的初始配置
4:在php文件中,如果有defautl的配置,会先找这个skin
5:如果应用了theme,程序会先去对应的theme目录下的skins中找配置文件
6:如果只是想给widget统一一个skin,建议用Customizing Widgets Globally
如果防止post跨站攻击
'request'=>array(
'enableCsrfValidation'=>true,
),
这时候生成的表单要用CHtml::form(),其会写一段代码在cookie中
防止Cookie攻击
'request'=>array(
'enableCookieValidation'=>true,
),
同时生成与得到cookie是要用 CHttpCookie
如何让表单验证不驼过的提示为中文
在main.php的配置中加上
'language' => 'zh_CN',
如何实现仿google的自动完成功能
<?php $this->widget('CAutoComplete', array(
'name'=>'xxx',
'url'=>array('suggestTags'),
'multiple'=>false,
'htmlOptions'=>array('size'=>50),
)); ?>
然后在url指定的地址中的方法中如下输出,即可
echo "a\nb\nc"
//CGridView详解
这东西在后台比较有用,能加速开发的速度,值得一看
CGridView用表格的方式显示数据项
每一行代表一个数据项,一列通常代表数据项的一个属性
CGridView支持排序和分页,可以用ajax或普通的方式
CgridView必序和data provider一起使用
最简单的用法
$dataprovider = new CActiveDataProvider('Post');
$this->widget('zii.widgets.grid.CGridView',array(
'dataProvider'=>$dataprovider,
));
这会用表格的方式显示每一条数据项,每一列是Post的一个属性
在显示中带了分页和排序
我们可以自定义CgridView::columns属性,以自定义表格列的显示方式
这个cloumns如何配置呢?
其是一个数组,每一个数组元素对应着一列的配置,可以是字符串或数组
1、如果是字符串,格式是name:type:header 后两者是可选的,根据这三个值,创建一个CdatColumn实例
其中type参见CFormatter
2、如果是数组,其可以实例化CDdataColumn、ClinkColumn,CButtonColumn,CCheckBoxColumn实例,具体实例化哪个
由数组中的class指定,默认是CDataColumn
2.1,如果class=>'CDataCloumn'
则可以指定name或者value,如果指定以value优先
用CDataColumn时如何以关联表的数据序列?
代码如下:表示可以post关联的author中的username排序列
$dataprovider = new CActiveDataProvider('Post',array(
'criteria'=>array(
'with'=>'author',
),
'sort'=>array(
'attributes'=>array(
'title','create_time',
'author_id'=>array('asc'=>'author.username asc','desc'=>'author.username desc','label'=>'作者')
)
),
));
$this->widget('zii.widgets.grid.CGridView',array(
'dataProvider'=>$dataprovider,
'columns'=>array(
'title',
'create_time',
array('name'=>'author_id','value'=>'$data->author->username'),
),
));
另外CDataColumn还有一个filter属性,如果是空,那么生成一个textfield,如果是数组(键值),则生成一个dropDownlist在当前列的上部,供搜索
2.2:如果class=>"CLinkColumn"
array('class'=>'CLinkColumn','label'=>'查看用户','url'=>Yii::app()->createURL('user/edit'))
则生成一个连接
2.3:如果class="CCheckBoxColumn"
array('class'=>'CCheckBoxColumn','name'=>'title','id'=>'select'),
可以生成一个checkbox供选择,且只能选一个
可以配置CGridView::selectableRows 如果是0,则不能选,如果 1,只选一个如果是2或其它值,则可以选多个
代码如下:
$this->widget('zii.widgets.grid.CGridView',array(
'dataProvider'=>$dataprovider,
'selectableRows'=>2,
'columns'=>array(
array('class'=>'CCheckBoxColumn','name'=>'title','id'=>'select'),
),
2.3:如果class="CButtonColumn"
array(
'class'=>'CButtonColumn',
'updateButtonUrl'=>'Yii::app()->createUrl("post/edit",array("id"=>$data->id));',
),
修改updateButtonUrl为编辑贴子
如何用gridview生成一个代搜索的管理列表
1、在Model的rules 设定可以搜索的属性
array('title, status, create_time', 'safe', 'on'=>'search'),
2、在Model中,添加搜索时的方法
public function search()
{
$criteria=new CDbCriteria;
$criteria->compare('title',$this->title,true);
$criteria->compare('status',$this->status);
$criteria->compare('create_time',$this->create_time);
return new CActiveDataProvider('Post', array(
'criteria'=>$criteria,
'sort'=>array(
'defaultOrder'=>'status, update_time DESC',
),
));
}
3、 在Controler中,写接受搜索用到的表单的值的方法
public function actionAdmin()
{
$model=new Post('search');
if(isset($_GET['Post']))
$model->attributes=$_GET['Post'];
$this->render('admin',array(
'model'=>$model,
));
}
4、在view中用CGridView显示
设置好
<?php $this->widget('zii.widgets.grid.CGridView', array(
'dataProvider'=>$model->search(),
'filter'=>$model,
'columns'=>array(
),
)); ?>
以上代码大部分是yii自动生成的,只要做少量修改即可
有时候会出现,搜索后页面为空的清况,原因可能是
layout/main.php中
echo $content外层无div,就是说main.php中必须有一个div包含$content
//CListView详解
其用列表的形式显示数据,不象CGridView一样,用表格显示数据,CListView用一个 view模板来显示每一条数据
其支持排序与分页
常用的代码如下
<?php
$dataProvider = new CActiveDataProvider('Post',array(
'pagination'=>array(
'pageSize'=>2
),
));
$this->widget('zii.widgets.CListView',array(
'dataProvider'=>$dataProvider,
'itemView'=>'_view',
'template'=>' {summary} {items} {pager}{sorter}',
'sortableAttributes'=>array(
'title',
'create_time'=>'Post Time',
),
));
//CActiveForm详解
快速生成表单,支持ajax验证,对于比较复杂的验下最好是自己生成表单,写验证方法
常用代码,在Controller中
public function actionForm()
{
$post = new Post();
if(isset($_POST['ajax']) && $_POST['ajax']==='post'){
echo CActiveForm::validate($post);
Yii::app()->end();
}
if(isset($_POST['Post'])){
$post->attributes = $_POST['Post'];
if($post->save()){
echo '存成功了';
}
}
$this->render('form',array('post'=>$post));
}
在view中
<?php
$form = $this->beginWidget('CActiveForm',array(
'id'=>'post',//这里与Controller中的ajax对应
'enableAjaxValidation'=>true,
));
?>
<?php echo CHtml::errorSummary($post); ?>
<?php echo $form->labelEx($post,'title');?>
<?php echo $form->textField($post,'title')?>
<?php echo $form->error($post,'title'); ?> error一定要写上,要不不会触发ajax验证
<?php echo $form->labelEx($post,'content');?>
<?php echo $form->textField($post,'content')?>
<?php echo CHtml::submitButton($post->isNewRecord ? 'Create' : 'Save'); ?>
<?php $this->endWidget(); ?>
//CBreadcrumbs常用代码
<?php $this->widget('zii.widgets.CBreadcrumbs', array(
'links'=>$this->breadcrumbs,
'homeLink'=>'<span><a href="http://abc.com">shouye</a></span>',
'separator'=>'>>>'
)); ?>
其中breadcrumbs中Controller中的一个属性,如果要出现导航,就要在view中给此属性附值
生成的html如下
<div class="breadcrumbs">
<span><a href="http://abc.com">shouye</a>
</span>>>><span>Managde Posts</span>>>>
<span>b</span>>>><span>c</span></div>
所以如果网站用到导航的时候,美工最好把导航代码定义如上
//CDetailView 用在仅仅是为了查看数据时,还是比较有用的,比如用在后台
如何在提交后显示一段提示
在控制器中
if(isset($_POST['name'])){
Yii::app()->user->setFlash('success','you are success');
$this->refresh();
}
在view中
if (Yii::app()->user->hasFlash('success')){
echo 're is'.Yii::app()->user->getFlash('success');
}else{
echo 'no';
}
如何得到当前域名:
app()->request->hostInfo
activeDropDownList,给出提示,并有值
array('empty'=>array(0=>'选择分组')
<input type="submit" class="btn" value="提交" />
验证码如何生成及验证:
Controller中
public function actions()
{
return array(
'captcha'=>array(
'class'=>'CCaptchaAction',
'backColor'=>0xFFFFFF,
'maxLength'=>4,
'minLength'=>4,
),
);
}
View中
<?php echo CHtml::activeTextField($user, 'verifyCode');?>
<?php $this->widget('CCaptcha',array(
'captchaAction' => '/site/captcha',
'showRefreshButton' => false,
'clickableImage' => true,
'imageOptions' => array('align'=>'top', 'title'=>'重新获取'),
));?>
Model中
array('verifyCode', 'captcha', 'captchaAction'=>'site/captcha', 'message' => '输入的验证码不正确'),
set_time_limit(0);//禁止角本超时
如何想把手工的东西记录的数据库
main.php中配置log
array(
'class'=>'CDbLogRoute',
'levels'=>'info',
'logTableName'=>'Log',
'connectionID'=>'db',
),
应用时
Yii::log('信息','info');
deleteAllByAttributes(array("phone"=>$phones)直接接受一个数组,可以删除数组中符合条件的记录
YII_BLOG STUDY重新看了一遍yii blog,有些记录会与上边的重复
YII:Trace() 在debug模式是才记录信息,同时在main.php中的Log中的配置中的levels中要有trace,至于记录多少
栈由index.php中的YII_TRACE_LEVEL决定
配置Gii
'modules'=>array(
'gii'=>array(
'class'=>'system.gii.GiiModule',
'password'=>'123',
),
),
获得客户端IP
if($_SERVER['HTTP_CLIENT_IP']){
$ip = $_SERVER['HTTP_CLIENT_IP'];
}elseif($_SERVER['HTTP_X_FORWARDED_FOR']){
$ip = $_SERVER['HTTP_X_FORWARDED_FOR'];
}else{
$ip = $_SERVER['REMOTE_ADDR'];
}
CActiveForm还是比较强大的,建议在以后的项目中form都用这个来实现
layout/中的视图是可以继承的
<?php $this->beginContent('/layouts/main'); ?>
然后在中间出现$content即可
<?php $this->endContent(); ?>
create,update最好是分开放在两个action中,共用一个form,中间可以加一层view,以在头尾显示不同的东西
成段的完成一个功能的代码尽量拿出来放到一个方法中
$this->beginWidget('CMarkdown', array('purifyOutput'=>true));
echo $data->content;
$this->endWidget();
linkButton,在删除时需要用js提示,可以看下这此组件中的comfirm
而且他们的提交方式都是post,是因为在jquery.yii.js写死了
具体的以在源文件中低部找到那段js中的ajaxsubmit,所在的js看下
filter是在执行action之前或之后执行的一段代码,要应用filters必须得写
CController::filters()方法
为什么在filters方法写上
return array(
'accessControl', // perform access control for CRUD operations
);能进行crud验证呢?
accessController是CContronller内置的filter,其调用
accessRules,得到验证规定,所以也要重写对应的accessRules,返回一个验证规则的数组成部分
if the application uses modules,
a root alias is also predefined for each module ID and refers to the base path of the corresponding module
如:echo YiiBase::getPathOfAlias('bbs');得到module bbs的路径
关于CUrlManager
'模式'=>'route'
matchValue是指,对于一个url规则,正常情况下是只看参数的名子是否一样就应用规则
如果matchValue=true,则也要看值
如,规则
'index-/<id:\d+>'=>array("book/index",'matchValue'=>false),
$this->createUrl('book/index', array('id'=>'abcd'));可以应用以上规则的,
如果规则中的matchValue=true,则就不能应用了
XSS又叫CSS (Cross Site Script) ,跨站脚本攻击。
它指的是恶意攻击者往Web页面里插入恶意html代码,当用户浏览该页之时,
嵌入其中Web里面的html代码会被执行
renderPartial()
render()
后者会把需要的js,css等嵌入
前者可以通过把最后一个参数设置成true完成一样的功能
addInCondition 不用考虑数组是空的情况yii会自动处理
如何得到当前url?
Yii::app()->request->url;
ctype_开始的几个函数,用于检查字任串是不是符合要求,代替了简单的正则表达式
CController中的setPageState可以保存同一页中的POST的表单状态
如何通过BEhavior修改CActiveRecord?
写类文件继承自
class LLog extends CActiveRecordBehavior{
public function beforeDelete($event){
$model = get_class($this->Owner);
//做要做的事,比如日志或修改模型字段内容
}
}
然后修改模型文件
public function behaviors()
{
return array(
// Classname => path to Class
'LLog'=>'application.behavior.LLog',
);
}
如何在应用程序处理请求之前执行一段操作?
在main.php中配置
'onBeginRequest' => 'function'
当然这个function方法要存在
也可以写在放口文件index.php中,代码改成如下
$app = Yii::createWebApplication($config);
$app->onbeginRequest = 'begin';
$app->run();
function begin(){
echo 'yyyyydddyyyyyy';
}
为什么在CActiveRecordBehavior中用
beforesave就可以代表了事件onBeforeSave
注意基为中最上边的events方法中返回的对应关系
'onBeforeSave'=>'beforeSave'
在调用attacth(CBehavior中)的时候,
$owner->attachEventHandler($event,array($this,$handler));
就指定了事件onBeforeSave的处理函数是用本类中的beforeSave
YII中的CComponent,CEvent与Behavior及CActiveRecordBehavior个人理解
这一块教程少,今天个人理解了下,写了个小例子,有助于理解
完成如下功能,一个JTool类,继承CComponent,当其长度改变时,调用事件,输出"change me".
JTool.php在protected/components 下
<?php
class JTool extends CComponent{
private $_width;
public function getWidth(){
return $this->_width ? $this->_width : 1;
}
public function setWidth($width){
if($this->hasEventHandler('onChange')){
$this->onChange(new CEvent());
}
$this->_width = $width;
}
public function onChange($event){
$this->raiseEvent('onChange', $event);
}
}
OK,功能已经实现了,找个控制器,执行
$j = new JTool();
$j->onChange = "showChange"; //给事件绑定handle showChange
$j->width = 100; //调用setWidth,解发绑定的事件showChange
function showChange(){
echo 'changed me';
}
现在我们想给JTool添加一个功能,返回长度的100倍,我们可以继承JTool.php写一个方法
class JToolSub extends JTool{
public function get100width(){
return $this->width*100;
}
}
OK,功能实现了,这个执行就简单了new JToolSub调用方法即可
上边的这两种办法,就是仅完成功能,下边演示Behavior及events来实现
如何用Behavior来实现上边的增加一个方法,返回长度的100倍的功能呢?
写类JBe
JBe.php在protected/behavior 下
class JBe extends CBehavior{
public function get100width(){
return $this->Owner->width*100;
}
}
OK,功能已经实现了,找个控制器,执行
$j = new JTool();
$j->attachBehavior('JBe', 'application.behavior.JBe');
echo $j->get100width();
如何用Behavior实现JTool中的长度改变时,调用一个事件的功能呢?
写类JBe
class JBe extends CBehavior{
public function events(){
return array_merge(parent::events(),array(
'onChange'=>'change',
));
}
public function change(){
echo 'changed';
}
public function get100width(){
return $this->Owner->width*100;
}
}
OK,功能实现随便找个控制器,执行
$j = new JTool();
$j->attachBehavior('JBe', 'application.behavior.JBe');
$j->width = 100;
这里的要点是events方法
返回的数组array('onChange'=>'change')定义了事件(event)和对应的事件处理方法(event hander)
事件是是Compents(JTool中)定义的,即JTool中的onChange
处理方法同由Behavior(JBe中)类定义的,即JBe中的change
这样子再看CActiveRecordBehavior,其是绑定给CActiveRecord 这个组件的,绑定方法重写behaviors()
CActiveRecordBehavior中的events() 方法返回事件及事处理函数的对应,如:
'onBeforeSave'=>'beforeSave'
即组件CActiveRecord中的onBeforeSave这个事件对应的处理函数是
CActiveRecordBehavior中的beforeSave方法
这样子CActiveRecord在调用save()时,触发事件onBeforeSave,调用CActiveRecordBehavior对应的处理函数beforeSave
我们只要写一个CActiveRecordBehavior的子类,重写其中的beforeSave,执行一些操作,然后给CActiveRecord绑定即可
如果你自己有个目录下有些类或文件常用,可以在main.php的最上边定义一个路径别名
Yii::setPathOfAlias('local','path/to/local-folder');
如果是多个可以在main.php中的array中加一个配置
'aliases'=>array(
'local'=>'path/to/local/'
),
如何得到proteced目录的物理路径?
YII::app()->basePath;
widget是发布资源
$url = Yii::app()->getAssetManager()->publish(Yii::getPathOfAlias('application.components.homeuserlived'));
cs()->registerCoreScript('jquery');
cs()->registerScriptFile($url.'/location.js' ,CClientScript::POS_HEAD);
cs()->registerScriptFile($url.'/YLChinaArea.js' ,CClientScript::POS_HEAD);
cs()->registerCssFile($url.'/style.css');
如何写application component, 即在main.php可配置
"my"=>array('')
可以通过Yii::app()->my来访问?
继承CApplicationComponent即可,并可以自带Behavior等
yii中读写session的两种方法
$session = Yii::app()->session;
$session['terry'] = 30;
var_dump($session['key']);
Yii::app()->user->setState('tom', '40');
var_dump(Yii::app()->user->getState('key', 'default'));
==========================================分隔线===================================
soap非yii教程,意思是不用yii框架的时候要对象提供webservice的写法
分两种WSDL模式,和非WSDL模式,先看后者
这个也比较简单,服务器端
server.php
<?php
ini_set('soap.wsdl_cache_enabled',0);
class Student {
public function getInfo($name,$age){
if($age == 20){
throw new SoapFault(-1, 'Cannot divide by zero!');
}
$xml = "<root><name>".$name."</name>";
$xml .= "<age>".$age."</age></root>";
return $xml;
}
}
$soapS = new SoapServer(null,array('uri' => 'http://www.dayouhui.com'));
$soapS->setClass('Student');
$soapS->handle();
?>
客户端client.php
<?php
$soap = new SoapClient(null,array('location'=>"http://localhost/mysoap/index.php",'uri'=>'inadex.php'));
echo $soap->getInfo('a','b');
这样子即可
=============================================
yii,Componnts那快,忘了,写了个小例子回忆了下
是写一个可以写在main.php中的Components并绑定行为,事件
======================================
class ExtWindow extends CApplicationComponent{
private $title = 'title';
public $oldtitle;
public function getTitle(){
return $this->title ? $this->title : 'old title<br />';
}
public function setTitle($title){
echo '=='.$this->oldtitle.'==';
$this->oldtitle = $this->title;
$this->title = $title;
if($this->hasEventHandler('onTitleChange')){
$event =new CEvent($this);
$this->raiseEvent('onTitleChange', $event);
}
}
//必须有这么个方法,其和raiseEent中的事件一样,具体看代码
public function onTitleChange($event){
}
}
===========================
<?php
class Window extends CBehavior{
public function events(){
return array_merge(parent::events(),array(
'onTitleChange'=>'titleChange',
));
}
public function titleChange($event){
echo $event->sender->title;
echo 'event TitleChange is handled in Behavior<br />';
echo $this->owner->title;
}
public function titleOld(){
echo '<br />old title is is '.$this->owner->oldtitle;
}
}
==============================
main.php中的写法
'ExtWin'=>array(
'class' => 'ExtWindow',
'oldtitle'=>'我是旧的',
'behaviors'=>array('win'=>'application..behavior.Window')
=============================================
一对多,多对多的关联时最后的参数 together说明
如果为false,分开查多个语句
如果为true,强制生成一个语句
如果没有设置,分页页生成多个语句,不分页时生成一个语句
),
多对多时,查询时,中间表的名子叫 (关联名_关联名)
with选项的作用是eager loading
together的作用是 要不要形成一个语句
当是一个sql语句是记录会有重复,这时候分页分出现相同的记录,加上group=>true即可,
只要弄明白了,你生成的sql是一条还是多条sql就明白在多对多查询时的结果了
两个表不是用主键关联
'user' => array(self::BELONGS_TO, 'OaskUser', '','on'=>'name=userName', 'select'=>'TrueName'),
需要开缓存
如何在页面下边显示sql的查询时间
在log组件的routes中加入
array(
'class'=>'CProfileLogRoute',
'levels'=>'error, warning',
)
同时在db组件中加入
'enableProfiling'=>true,
同时在这种情况下,可以用CDbConnection::getStats() 查看执行了多少个语句,用了多少时间
如何知道某一个程序段运行需要的时间
配置好CProfileLogRoute后,在需要测试的地方加上
Yii::beginProfile('blockID');
//程序段
Yii::endProfile('blockID');
'enableParamLogging'=>true,的作用是?
在日志的bind的参数后边跟数的值
如何在页面底部显示所有的db相关的日志
同上,配置log组件的routes中加入
array(
'class'=>'CWebLogRoute',
'levels'=>'trace, info, error, warning',
'categories' => 'system.db.*',
//'showInFireBug' => true, 将在firebug中显示日志
),
把日志记录到数据库
array(
'class'=>'CDbLogRoute',
'logTableName'=>'applog',
'connectionID'=>'db',
),
运行时表applog会自动生成,如果不能生成,参照api自已建立
如何记录$_GET,$_SESSION等信息,在以上的routes中各个配置中加上
'filter'=>'CLogFilter',
log配置中的level设置不对,可能会得不到日志信息
另外level,category的值可以随便写,
只要在用yii::Log("","自定义level","自定义的category")时对应起来即可
如何记录更详细的信息,能记录stack,在入口文件中加上
define('YII_TRACE_LEVEL',10);数字越大,记当的越详细,结果如下
[15:31:57.226][trace][system.db.CDbCommand] Querying SQL: SHOW COLUMNS FROM `Bangdan` in E:\APMServ5.2.6\www\htdocs\dayouhui.com\protected\models\Bangdan.php (21)
in E:\APMServ5.2.6\www\htdocs\dayouhui.com\protected\components\HotBangdan.php (21) in E:\APMServ5.2.6
如果在调试时,终止程序运行且看到日志,不能用die及exit;
用application::end,即Yii::app()->end(),其会触发onEndRequest事件,日志就是在这个事件中记录的
activeRecord几个占位方法重写的注意点
必须带boolean返回值
如何发布一个资源文件并引用
$css=Yii::app()->getAssetManager()->publish(dirname(__FILE__)."/aa.css");
yii::app()->clientScript->registerCssFIle($css);
如果改变activelable中默认的标题
重写方法attributeLabels
过滤不良代码
$purifier=new CHtmlPurifier;
$purifier->options=array("HTML.Allowed"=>"div");
$content=$purifier->purify($content);
或者
<?php $this->beginWidget('CHtmlPurifier'); ?>
...display user-entered content here...
<?php $this->endWidget(); ?>
如何防止重复提交?
提交后
Ccontroler->refresh();
如何在成功后显示一个提示,用户刷新页时去掉提示
Cwebuser->setFlash();
getFlash();
如何防止重复提交, 并在提交成功后给出提示?
控制器中
Yii::app()->user->setFlash('submit','thanks');
$this->refresh();
view中
if(Yii::app()->user->hasFlash('submit')){
echo Yii::app()->user->getFlash('submit');
}
一般我们是跳转到列表页,或用redirect跳到编辑页,就不需要了,如果还是要显示当前页
以上就有用了,比如在当前时显示,编辑或添加新的记录
如何分页
itemCount总记录条数
CPagination代表分页信息,有多少页,每页几条记录等
CLinkPager生成分页的代码,自定义css可以给属性cssFile一个值
$criteria=new CDbCriteria();
$pages=new CPagination("数据库中的总记录数");
$pages->pageSize=2;
$pages->applyLimit($criteria);//给$criteria->limit offset等符值
$posts=Post::model()->findAll($criteria);
$this->widget('CLinkPager',array('pages'=>$pages));
列表如何排序
$criteria=new CDbCriteria();
$sort = new CSort('Post');
$sort->defaultOrder=" status asc";
$sort->applyOrder($criteria);
$posts=Post::model()->findAll($criteria);
应用时用
$sort->link('字段名')
实际是生成一个带参数的url,然后在在applyOrder时应用这些参数修改$criteria,得到相应的查寻结果
如何生成并验证验证码:
基本用法
<?php $this->widget('CCaptcha'); ?> 具体参数查手册
原理CCaptcha这个widget会在run时调用当前控制器的$captchaAction='captcha'方法,这个方法指到一个类CCaptchaAction
其会生成验证码图象,并记入到session中
如何显示静态页
重写actions
'help'=>array(
'class'=>'CViewAction',
'basePath'=>'help', //指定目录名
'defaultView'=>'default',
'viewParam'=>'help' //get参数
),
假定当前控制器是post
那么可以能过/post/help/help/content访问help目录下的content.php
可以建立子目录比如help/reigterhelp/content.那可以通过/post/help/help/registerhelp.content来访问
用CViewAction的好处时,可以与其它的view共享layout
关于没有权限访问跳转的url相关
当没有权限时调用CAccessControlFilter类中的accessDenied,其调用CwebUser中的loginRequired(),记录当前的returnurl后跳转到
CWebUser配置中的loginurl,在此处登陆后,可以通过redirect跳转到returnurl(Yii::app()->request->redirect(Yii::app()->user->returnUrl);)
当强制显示登陆表单,比如判断用户是guest就一直列出登陆表单,不会调用loginRequired, 就得不到returnurl,这时候想跳回去,参见
cookbook上相关贴子
registerCoreScript
在framework/web/js/package.php中列出的才是
多对多关联条件
$criteria->addInCondition("categorys.id",$in);
$criteria->addSearchCondition('Shop.name',$keyword);
$shops=Shop::model()->with(array("categorys"=>array('together'=>true)))->findAll($criteria);
同时要在Shop模型中加入alias="categorys" ,另外together=true放在模型的关联中也可
YII中的RBAC权限,用数据库存item,
在system/web/auth下找到相应的sql导放到数据库中
配置'authManager' => array(
'class' => 'CDbAuthManager',
'connectionID' => 'db',
),
如果在sql中导入的三个表的表名不是默认的,需要在这上边的配置中配置,具体的看api
$auth=Yii::app()->authManager;
//$auth->createOperation("post",'postpost');
//$auth->createTask("post","posts");
$auth->createRole("post","post");
auth->assign("post",'demo');
if(Yii::app()->user->checkAccess("post")){
echo "yes";
else{
echo "no";
}
这种情况下三者是一样的
如何获得上一页的url以返回
Yii::app()->request->urlReferrer;
accessControl 是Ccontroller中内置的过滤方法,其它的还有ajaxOnly postOnly
CMaskedTextField此组件用于限制用户的输入,对应的jquery插件http://digitalbush.com/projects/masked-input-plugin/
在一对多,多对多查询时,the eager loading 联合所有的表生成一条语句,如果主表有limit的查询选项,那么他将单独执行,然后再执行与关联表有关的语句,返回相关表的数据对象,这
就是为什么在做大优惠时,以中间表为查询条件出错的原因,解决办法
with()返回 CActiveFinder对象,其方法together(),既使主表中有LIMIT/OFFSET 也是返回一条sql;
多对多查询时,分页有时候页中显示的条数不正确,因为有重复的项,加上$criteria->group = true即可
模型的rules中,验证某个字段不能重复,array('name', 'unique','message' => '有重复的名子'),
CStatePersister是yii的核心组件,提供了基于文件的数据保存方式,可以不在同的请求中使用
COutputCache 即是一个组件,又是一个filter,前者的时候用于在view中缓存内容,后者的时候用于在controller中缓存
就是说片段缓存,是把COutputCache当一个widget来用,页面缓存把COutputCache当作一个filter来用
动态缓存,用CController的一个方法 renderDynamic($callback);
COutputCache几个属性,duration,dependency
另外还有几个,可以通称为Variation, 有什么作用呢?
在beginCache是需要手工指定一个id,Variation的作有就是自动给生成这个id
在布署模式的时候,有错误不会有stack样的提示,会显示一个errorxxx的错误
如何在程序有错的时候跳到指定的action
在components中设置
'errorHandler'=>array(
'errorAction'=>'site/error',
),
在此action中可以能过Yii::app()->errorHandler->error获得错误信息
把字符串分解成数组,并去掉空值
preg_split('/\s*,\s*/','this , is , , a test',-1,PREG_SPLIT_NO_EMPTY )
CActiveRecord::exits();判断有没有这样的记录,一般用于添加时,判断某字段有没有重复
CActiveDataProvider 一个基于ActiveRecord的数据提供源
常用的用法
$dataProvider=new CActiveDataProvider('Post', array(
'criteria'=>array(),
'pagination'=>array(),
'sort'=>array(),
));
上如'sort'=>array(
'defaultOrder'=>'status, update_time DESC',
),
ClistView同上结合使用,其中的_view中可以用一个$data的变量,代表当前的model数据
如果dataProvider中的pagination,sort设为false,则CliveView中对应的部分也无法使用
$this->widget('zii.widgets.ClistView',array(
'dataProvider' => $dataprovider,
'itemView' => '_view',
'template' => '{items}{sorter}{pager}',
'sortableAttributes' => array(
),
));
CGridView的使用也结合$dataprovider,
用的时候主要是对columns的配置,主要有
CDataColumn, CLinkColumn, CButtonColumn and CCheckBoxColumn.具体用法看api
总的说来CgridView没有ClistView灵活
插入meta信息
Yii::app()->clientScript->registerMetaTag('keywords','关键字');
Yii::app()->clientScript->registerMetaTag('description','一些描述');
CMap::mergeArray() 比array_merge更智能的合并数组,yii中配置的合并用这个
CClipWidget 通过ob_start ob_getconent生成一段不显示的内容,可以能过CController::clips访问,如
$this->beginWidget('CClipWidget',array('id'=>'name','renderClip'=>true));
可以通过$this->clips['name']来显示,其中的renderClip如果为false,则在当前位置不显示内容
如果在Model一次验证多个属于,显示不同的内容?如下 [后来发现这个不起作有]
return array(
array('title, content', 'required',
'message'=>'Please enter a value for {attribute}.'),
// ... other rules
);
获得服务器时间
$_SERVER['REQUEST_TIME']
维护程序时,这样子所有的请求转发到一个地方
'catchAllRequest'=>array('site/all'),
根据二级域名缓存
array(
'COutputCache + search',
'duration' => 120,
'varyByParam' => array('q','page'),
'varyByExpression' => "app()->request->hostInfo",
),
有多个分站时,同步登陆,基于cookie
'user'=>array(
'identityCookie'=>array('domain'=>'.dayouhui.com'),
'allowAutoLogin' => true,
)
如果是基本于session
'session' => array(
'cookieParams' => array('domain' => '.dayouhui', 'lifetime' => 0),
'timeout' => 3600,
),
如何使用theme
在main.php中配置
'theme'=>'classic',
如何得到前前使用的主题
Yii::app()->theme
得到名子
Yii::app()->theme->name;
themes文件夹和protected是同级的,其下边某个theme的目录结果同protected/views下一样
关于skin
用theme改变view的外观,skin是用来改变widgets的外观的
skin是健值对用于初始化一个widget的属性
要对widget使用skin,需要做以下几步
1:配置'widgetFactory'=>array(
'enableSkin'=>true,
),
2:在views下建立skins目录
3:在skins目录下建立与Widget名子一样的php文件,返回数组,即能用于widget的初始配置
4:在php文件中,如果有defautl的配置,会先找这个skin
5:如果应用了theme,程序会先去对应的theme目录下的skins中找配置文件
6:如果只是想给widget统一一个skin,建议用Customizing Widgets Globally
如果防止post跨站攻击
'request'=>array(
'enableCsrfValidation'=>true,
),
这时候生成的表单要用CHtml::form(),其会写一段代码在cookie中
防止Cookie攻击
'request'=>array(
'enableCookieValidation'=>true,
),
同时生成与得到cookie是要用 CHttpCookie
如何让表单验证不驼过的提示为中文
在main.php的配置中加上
'language' => 'zh_CN',
如何实现仿google的自动完成功能
<?php $this->widget('CAutoComplete', array(
'name'=>'xxx',
'url'=>array('suggestTags'),
'multiple'=>false,
'htmlOptions'=>array('size'=>50),
)); ?>
然后在url指定的地址中的方法中如下输出,即可
echo "a\nb\nc"
//CGridView详解
这东西在后台比较有用,能加速开发的速度,值得一看
CGridView用表格的方式显示数据项
每一行代表一个数据项,一列通常代表数据项的一个属性
CGridView支持排序和分页,可以用ajax或普通的方式
CgridView必序和data provider一起使用
最简单的用法
$dataprovider = new CActiveDataProvider('Post');
$this->widget('zii.widgets.grid.CGridView',array(
'dataProvider'=>$dataprovider,
));
这会用表格的方式显示每一条数据项,每一列是Post的一个属性
在显示中带了分页和排序
我们可以自定义CgridView::columns属性,以自定义表格列的显示方式
这个cloumns如何配置呢?
其是一个数组,每一个数组元素对应着一列的配置,可以是字符串或数组
1、如果是字符串,格式是name:type:header 后两者是可选的,根据这三个值,创建一个CdatColumn实例
其中type参见CFormatter
2、如果是数组,其可以实例化CDdataColumn、ClinkColumn,CButtonColumn,CCheckBoxColumn实例,具体实例化哪个
由数组中的class指定,默认是CDataColumn
2.1,如果class=>'CDataCloumn'
则可以指定name或者value,如果指定以value优先
用CDataColumn时如何以关联表的数据序列?
代码如下:表示可以post关联的author中的username排序列
$dataprovider = new CActiveDataProvider('Post',array(
'criteria'=>array(
'with'=>'author',
),
'sort'=>array(
'attributes'=>array(
'title','create_time',
'author_id'=>array('asc'=>'author.username asc','desc'=>'author.username desc','label'=>'作者')
)
),
));
$this->widget('zii.widgets.grid.CGridView',array(
'dataProvider'=>$dataprovider,
'columns'=>array(
'title',
'create_time',
array('name'=>'author_id','value'=>'$data->author->username'),
),
));
另外CDataColumn还有一个filter属性,如果是空,那么生成一个textfield,如果是数组(键值),则生成一个dropDownlist在当前列的上部,供搜索
2.2:如果class=>"CLinkColumn"
array('class'=>'CLinkColumn','label'=>'查看用户','url'=>Yii::app()->createURL('user/edit'))
则生成一个连接
2.3:如果class="CCheckBoxColumn"
array('class'=>'CCheckBoxColumn','name'=>'title','id'=>'select'),
可以生成一个checkbox供选择,且只能选一个
可以配置CGridView::selectableRows 如果是0,则不能选,如果 1,只选一个如果是2或其它值,则可以选多个
代码如下:
$this->widget('zii.widgets.grid.CGridView',array(
'dataProvider'=>$dataprovider,
'selectableRows'=>2,
'columns'=>array(
array('class'=>'CCheckBoxColumn','name'=>'title','id'=>'select'),
),
2.3:如果class="CButtonColumn"
array(
'class'=>'CButtonColumn',
'updateButtonUrl'=>'Yii::app()->createUrl("post/edit",array("id"=>$data->id));',
),
修改updateButtonUrl为编辑贴子
如何用gridview生成一个代搜索的管理列表
1、在Model的rules 设定可以搜索的属性
array('title, status, create_time', 'safe', 'on'=>'search'),
2、在Model中,添加搜索时的方法
public function search()
{
$criteria=new CDbCriteria;
$criteria->compare('title',$this->title,true);
$criteria->compare('status',$this->status);
$criteria->compare('create_time',$this->create_time);
return new CActiveDataProvider('Post', array(
'criteria'=>$criteria,
'sort'=>array(
'defaultOrder'=>'status, update_time DESC',
),
));
}
3、 在Controler中,写接受搜索用到的表单的值的方法
public function actionAdmin()
{
$model=new Post('search');
if(isset($_GET['Post']))
$model->attributes=$_GET['Post'];
$this->render('admin',array(
'model'=>$model,
));
}
4、在view中用CGridView显示
设置好
<?php $this->widget('zii.widgets.grid.CGridView', array(
'dataProvider'=>$model->search(),
'filter'=>$model,
'columns'=>array(
),
)); ?>
以上代码大部分是yii自动生成的,只要做少量修改即可
有时候会出现,搜索后页面为空的清况,原因可能是
layout/main.php中
echo $content外层无div,就是说main.php中必须有一个div包含$content
//CListView详解
其用列表的形式显示数据,不象CGridView一样,用表格显示数据,CListView用一个 view模板来显示每一条数据
其支持排序与分页
常用的代码如下
<?php
$dataProvider = new CActiveDataProvider('Post',array(
'pagination'=>array(
'pageSize'=>2
),
));
$this->widget('zii.widgets.CListView',array(
'dataProvider'=>$dataProvider,
'itemView'=>'_view',
'template'=>' {summary} {items} {pager}{sorter}',
'sortableAttributes'=>array(
'title',
'create_time'=>'Post Time',
),
));
//CActiveForm详解
快速生成表单,支持ajax验证,对于比较复杂的验下最好是自己生成表单,写验证方法
常用代码,在Controller中
public function actionForm()
{
$post = new Post();
if(isset($_POST['ajax']) && $_POST['ajax']==='post'){
echo CActiveForm::validate($post);
Yii::app()->end();
}
if(isset($_POST['Post'])){
$post->attributes = $_POST['Post'];
if($post->save()){
echo '存成功了';
}
}
$this->render('form',array('post'=>$post));
}
在view中
<?php
$form = $this->beginWidget('CActiveForm',array(
'id'=>'post',//这里与Controller中的ajax对应
'enableAjaxValidation'=>true,
));
?>
<?php echo CHtml::errorSummary($post); ?>
<?php echo $form->labelEx($post,'title');?>
<?php echo $form->textField($post,'title')?>
<?php echo $form->error($post,'title'); ?> error一定要写上,要不不会触发ajax验证
<?php echo $form->labelEx($post,'content');?>
<?php echo $form->textField($post,'content')?>
<?php echo CHtml::submitButton($post->isNewRecord ? 'Create' : 'Save'); ?>
<?php $this->endWidget(); ?>
//CBreadcrumbs常用代码
<?php $this->widget('zii.widgets.CBreadcrumbs', array(
'links'=>$this->breadcrumbs,
'homeLink'=>'<span><a href="http://abc.com">shouye</a></span>',
'separator'=>'>>>'
)); ?>
其中breadcrumbs中Controller中的一个属性,如果要出现导航,就要在view中给此属性附值
生成的html如下
<div class="breadcrumbs">
<span><a href="http://abc.com">shouye</a>
</span>>>><span>Managde Posts</span>>>>
<span>b</span>>>><span>c</span></div>
所以如果网站用到导航的时候,美工最好把导航代码定义如上
//CDetailView 用在仅仅是为了查看数据时,还是比较有用的,比如用在后台
如何在提交后显示一段提示
在控制器中
if(isset($_POST['name'])){
Yii::app()->user->setFlash('success','you are success');
$this->refresh();
}
在view中
if (Yii::app()->user->hasFlash('success')){
echo 're is'.Yii::app()->user->getFlash('success');
}else{
echo 'no';
}
如何得到当前域名:
app()->request->hostInfo
activeDropDownList,给出提示,并有值
array('empty'=>array(0=>'选择分组')
<input type="submit" class="btn" value="提交" />
验证码如何生成及验证:
Controller中
public function actions()
{
return array(
'captcha'=>array(
'class'=>'CCaptchaAction',
'backColor'=>0xFFFFFF,
'maxLength'=>4,
'minLength'=>4,
),
);
}
View中
<?php echo CHtml::activeTextField($user, 'verifyCode');?>
<?php $this->widget('CCaptcha',array(
'captchaAction' => '/site/captcha',
'showRefreshButton' => false,
'clickableImage' => true,
'imageOptions' => array('align'=>'top', 'title'=>'重新获取'),
));?>
Model中
array('verifyCode', 'captcha', 'captchaAction'=>'site/captcha', 'message' => '输入的验证码不正确'),
set_time_limit(0);//禁止角本超时
如何想把手工的东西记录的数据库
main.php中配置log
array(
'class'=>'CDbLogRoute',
'levels'=>'info',
'logTableName'=>'Log',
'connectionID'=>'db',
),
应用时
Yii::log('信息','info');
deleteAllByAttributes(array("phone"=>$phones)直接接受一个数组,可以删除数组中符合条件的记录
YII_BLOG STUDY重新看了一遍yii blog,有些记录会与上边的重复
YII:Trace() 在debug模式是才记录信息,同时在main.php中的Log中的配置中的levels中要有trace,至于记录多少
栈由index.php中的YII_TRACE_LEVEL决定
配置Gii
'modules'=>array(
'gii'=>array(
'class'=>'system.gii.GiiModule',
'password'=>'123',
),
),
获得客户端IP
if($_SERVER['HTTP_CLIENT_IP']){
$ip = $_SERVER['HTTP_CLIENT_IP'];
}elseif($_SERVER['HTTP_X_FORWARDED_FOR']){
$ip = $_SERVER['HTTP_X_FORWARDED_FOR'];
}else{
$ip = $_SERVER['REMOTE_ADDR'];
}
CActiveForm还是比较强大的,建议在以后的项目中form都用这个来实现
layout/中的视图是可以继承的
<?php $this->beginContent('/layouts/main'); ?>
然后在中间出现$content即可
<?php $this->endContent(); ?>
create,update最好是分开放在两个action中,共用一个form,中间可以加一层view,以在头尾显示不同的东西
成段的完成一个功能的代码尽量拿出来放到一个方法中
$this->beginWidget('CMarkdown', array('purifyOutput'=>true));
echo $data->content;
$this->endWidget();
linkButton,在删除时需要用js提示,可以看下这此组件中的comfirm
而且他们的提交方式都是post,是因为在jquery.yii.js写死了
具体的以在源文件中低部找到那段js中的ajaxsubmit,所在的js看下
filter是在执行action之前或之后执行的一段代码,要应用filters必须得写
CController::filters()方法
为什么在filters方法写上
return array(
'accessControl', // perform access control for CRUD operations
);能进行crud验证呢?
accessController是CContronller内置的filter,其调用
accessRules,得到验证规定,所以也要重写对应的accessRules,返回一个验证规则的数组成部分
if the application uses modules,
a root alias is also predefined for each module ID and refers to the base path of the corresponding module
如:echo YiiBase::getPathOfAlias('bbs');得到module bbs的路径
关于CUrlManager
'模式'=>'route'
matchValue是指,对于一个url规则,正常情况下是只看参数的名子是否一样就应用规则
如果matchValue=true,则也要看值
如,规则
'index-/<id:\d+>'=>array("book/index",'matchValue'=>false),
$this->createUrl('book/index', array('id'=>'abcd'));可以应用以上规则的,
如果规则中的matchValue=true,则就不能应用了
XSS又叫CSS (Cross Site Script) ,跨站脚本攻击。
它指的是恶意攻击者往Web页面里插入恶意html代码,当用户浏览该页之时,
嵌入其中Web里面的html代码会被执行
renderPartial()
render()
后者会把需要的js,css等嵌入
前者可以通过把最后一个参数设置成true完成一样的功能
addInCondition 不用考虑数组是空的情况yii会自动处理
如何得到当前url?
Yii::app()->request->url;
ctype_开始的几个函数,用于检查字任串是不是符合要求,代替了简单的正则表达式
CController中的setPageState可以保存同一页中的POST的表单状态
如何通过BEhavior修改CActiveRecord?
写类文件继承自
class LLog extends CActiveRecordBehavior{
public function beforeDelete($event){
$model = get_class($this->Owner);
//做要做的事,比如日志或修改模型字段内容
}
}
然后修改模型文件
public function behaviors()
{
return array(
// Classname => path to Class
'LLog'=>'application.behavior.LLog',
);
}
如何在应用程序处理请求之前执行一段操作?
在main.php中配置
'onBeginRequest' => 'function'
当然这个function方法要存在
也可以写在放口文件index.php中,代码改成如下
$app = Yii::createWebApplication($config);
$app->onbeginRequest = 'begin';
$app->run();
function begin(){
echo 'yyyyydddyyyyyy';
}
为什么在CActiveRecordBehavior中用
beforesave就可以代表了事件onBeforeSave
注意基为中最上边的events方法中返回的对应关系
'onBeforeSave'=>'beforeSave'
在调用attacth(CBehavior中)的时候,
$owner->attachEventHandler($event,array($this,$handler));
就指定了事件onBeforeSave的处理函数是用本类中的beforeSave
YII中的CComponent,CEvent与Behavior及CActiveRecordBehavior个人理解
这一块教程少,今天个人理解了下,写了个小例子,有助于理解
完成如下功能,一个JTool类,继承CComponent,当其长度改变时,调用事件,输出"change me".
JTool.php在protected/components 下
<?php
class JTool extends CComponent{
private $_width;
public function getWidth(){
return $this->_width ? $this->_width : 1;
}
public function setWidth($width){
if($this->hasEventHandler('onChange')){
$this->onChange(new CEvent());
}
$this->_width = $width;
}
public function onChange($event){
$this->raiseEvent('onChange', $event);
}
}
OK,功能已经实现了,找个控制器,执行
$j = new JTool();
$j->onChange = "showChange"; //给事件绑定handle showChange
$j->width = 100; //调用setWidth,解发绑定的事件showChange
function showChange(){
echo 'changed me';
}
现在我们想给JTool添加一个功能,返回长度的100倍,我们可以继承JTool.php写一个方法
class JToolSub extends JTool{
public function get100width(){
return $this->width*100;
}
}
OK,功能实现了,这个执行就简单了new JToolSub调用方法即可
上边的这两种办法,就是仅完成功能,下边演示Behavior及events来实现
如何用Behavior来实现上边的增加一个方法,返回长度的100倍的功能呢?
写类JBe
JBe.php在protected/behavior 下
class JBe extends CBehavior{
public function get100width(){
return $this->Owner->width*100;
}
}
OK,功能已经实现了,找个控制器,执行
$j = new JTool();
$j->attachBehavior('JBe', 'application.behavior.JBe');
echo $j->get100width();
如何用Behavior实现JTool中的长度改变时,调用一个事件的功能呢?
写类JBe
class JBe extends CBehavior{
public function events(){
return array_merge(parent::events(),array(
'onChange'=>'change',
));
}
public function change(){
echo 'changed';
}
public function get100width(){
return $this->Owner->width*100;
}
}
OK,功能实现随便找个控制器,执行
$j = new JTool();
$j->attachBehavior('JBe', 'application.behavior.JBe');
$j->width = 100;
这里的要点是events方法
返回的数组array('onChange'=>'change')定义了事件(event)和对应的事件处理方法(event hander)
事件是是Compents(JTool中)定义的,即JTool中的onChange
处理方法同由Behavior(JBe中)类定义的,即JBe中的change
这样子再看CActiveRecordBehavior,其是绑定给CActiveRecord 这个组件的,绑定方法重写behaviors()
CActiveRecordBehavior中的events() 方法返回事件及事处理函数的对应,如:
'onBeforeSave'=>'beforeSave'
即组件CActiveRecord中的onBeforeSave这个事件对应的处理函数是
CActiveRecordBehavior中的beforeSave方法
这样子CActiveRecord在调用save()时,触发事件onBeforeSave,调用CActiveRecordBehavior对应的处理函数beforeSave
我们只要写一个CActiveRecordBehavior的子类,重写其中的beforeSave,执行一些操作,然后给CActiveRecord绑定即可
如果你自己有个目录下有些类或文件常用,可以在main.php的最上边定义一个路径别名
Yii::setPathOfAlias('local','path/to/local-folder');
如果是多个可以在main.php中的array中加一个配置
'aliases'=>array(
'local'=>'path/to/local/'
),
如何得到proteced目录的物理路径?
YII::app()->basePath;
widget是发布资源
$url = Yii::app()->getAssetManager()->publish(Yii::getPathOfAlias('application.components.homeuserlived'));
cs()->registerCoreScript('jquery');
cs()->registerScriptFile($url.'/location.js' ,CClientScript::POS_HEAD);
cs()->registerScriptFile($url.'/YLChinaArea.js' ,CClientScript::POS_HEAD);
cs()->registerCssFile($url.'/style.css');
如何写application component, 即在main.php可配置
"my"=>array('')
可以通过Yii::app()->my来访问?
继承CApplicationComponent即可,并可以自带Behavior等
yii中读写session的两种方法
$session = Yii::app()->session;
$session['terry'] = 30;
var_dump($session['key']);
Yii::app()->user->setState('tom', '40');
var_dump(Yii::app()->user->getState('key', 'default'));
==========================================分隔线===================================
soap非yii教程,意思是不用yii框架的时候要对象提供webservice的写法
分两种WSDL模式,和非WSDL模式,先看后者
这个也比较简单,服务器端
server.php
<?php
ini_set('soap.wsdl_cache_enabled',0);
class Student {
public function getInfo($name,$age){
if($age == 20){
throw new SoapFault(-1, 'Cannot divide by zero!');
}
$xml = "<root><name>".$name."</name>";
$xml .= "<age>".$age."</age></root>";
return $xml;
}
}
$soapS = new SoapServer(null,array('uri' => 'http://www.dayouhui.com'));
$soapS->setClass('Student');
$soapS->handle();
?>
客户端client.php
<?php
$soap = new SoapClient(null,array('location'=>"http://localhost/mysoap/index.php",'uri'=>'inadex.php'));
echo $soap->getInfo('a','b');
这样子即可
=============================================
yii,Componnts那快,忘了,写了个小例子回忆了下
是写一个可以写在main.php中的Components并绑定行为,事件
======================================
class ExtWindow extends CApplicationComponent{
private $title = 'title';
public $oldtitle;
public function getTitle(){
return $this->title ? $this->title : 'old title<br />';
}
public function setTitle($title){
echo '=='.$this->oldtitle.'==';
$this->oldtitle = $this->title;
$this->title = $title;
if($this->hasEventHandler('onTitleChange')){
$event =new CEvent($this);
$this->raiseEvent('onTitleChange', $event);
}
}
//必须有这么个方法,其和raiseEent中的事件一样,具体看代码
public function onTitleChange($event){
}
}
===========================
<?php
class Window extends CBehavior{
public function events(){
return array_merge(parent::events(),array(
'onTitleChange'=>'titleChange',
));
}
public function titleChange($event){
echo $event->sender->title;
echo 'event TitleChange is handled in Behavior<br />';
echo $this->owner->title;
}
public function titleOld(){
echo '<br />old title is is '.$this->owner->oldtitle;
}
}
==============================
main.php中的写法
'ExtWin'=>array(
'class' => 'ExtWindow',
'oldtitle'=>'我是旧的',
'behaviors'=>array('win'=>'application..behavior.Window')
=============================================
一对多,多对多的关联时最后的参数 together说明
如果为false,分开查多个语句
如果为true,强制生成一个语句
如果没有设置,分页页生成多个语句,不分页时生成一个语句
),
多对多时,查询时,中间表的名子叫 (关联名_关联名)
with选项的作用是eager loading
together的作用是 要不要形成一个语句
当是一个sql语句是记录会有重复,这时候分页分出现相同的记录,加上group=>true即可,
只要弄明白了,你生成的sql是一条还是多条sql就明白在多对多查询时的结果了
两个表不是用主键关联
'user' => array(self::BELONGS_TO, 'OaskUser', '','on'=>'name=userName', 'select'=>'TrueName'),
发表评论
-
Yii CDBHttpSession数据库存储session性能优化实战
2011-09-14 20:11 946Yii CDBHttpSession数据库存储session性 ... -
YII CACHE使用示例
2011-08-29 21:58 3981从Boylee那抄过来的.链接中有boylee的博客地址. 我 ... -
Yii CDBHttpSession数据库存储session性能优化实战
2011-08-29 21:36 4259Yii CDBHttpSession数据库存储session性 ... -
通过扩展CWebUser添加信息到Yii:app()->user
2011-08-29 21:21 3559通过扩展CWebUser添加信息到Yii:app()-> ... -
通过扩展 CWebUser 增加信息到 Yii::app()->user
2011-05-25 11:16 7590通过扩展 CWebUser 增加信息到 Yii::app()- ... -
Gridview日期过滤列(filter date column for gridview in Yii framework)
2011-05-23 11:02 5104Gridview日期过滤列(filter da ... -
利用yii framework dropdown 创建级联菜单
2011-05-23 10:57 2423利用yii framework dropdown 创建级联菜单 ... -
如何开发Yii的中文网站
2011-05-23 10:50 5120如何开发Yii的中文网站 首先在配置文件main.php 中 ... -
Yii CGridView 详解(关键看关联表字段排序部分)
2011-05-23 10:47 6982Yii CGridView 详解(关键看关联表字段排序部分) ... -
总结一下隐藏index.php文件的步骤
2011-05-23 10:07 1586总结一下隐藏index.php文件的步骤 1.开启apache ... -
Yii Framework的CPagination用法详解
2011-05-22 17:52 3274Yii Framework的CPagination用法详解 c ... -
yii ajax分页
2011-05-22 16:24 1883我们有时候需要ajax读取数据,并进行分页。首先我们遇到的是如 ... -
yii中widget分页的用法
2011-05-22 16:15 4162yii中widget分页的用法 1首先contr ... -
YII全局函数使用
2011-05-21 08:57 4625由于YII致力于完美的整合第三方库,它并没有定义任何全局函数。 ... -
Yii框架中ActiveRecord使用Relations
2011-05-21 06:55 2036Yii框架中ActiveRecord使用Relations ... -
转:关于yii的relations
2011-05-20 16:53 2615关于yii的relations . ... -
使用GD库生成验证码
2011-05-14 21:19 1195GD库在php 中的另一个重要的应用,是使用GD库生 ... -
smarty插件:在多少分钟前,多少小时前,多少天前。
2011-05-14 21:11 1296smarty插件:在多少分钟前,多少小时前,多少天前。 ... -
yii快速入门与参考
2011-05-04 09:17 5522yii快速入门与参考 ...
相关推荐
全国大学生智能汽车竞赛自2006年起,由教育部高等教育司委托高等学校自动化类教学指导委员会举办,旨在加强学生实践、创新能力和培养团队精神的一项创意性科技竞赛。该竞赛至今已成功举办多届,吸引了众多高校学生的积极参与,此文件为智能车竞赛介绍
字卡v4.3.4 原版 三种UI+关键字卡控制+支持获取用户信息+支持强制关注 集卡模块从一开始的版本到助力版本再到现在的新规则版本。 集卡模块难度主要在于 如何控制各种不同的字卡组合 被粉丝集齐的数量。 如果不控制那么一定会出现超过数量的粉丝集到指定的字卡组合,造成奖品不够的混乱,如果大奖价值高的话,超过数量的粉丝集到大奖后,就造成商家的活动费用超支了。我们冥思苦想如何才能限制集到指定字卡组合的粉丝数,后我们想到了和支付宝一样的选一张关键字卡来进行规则设置的方式来进行限制,根据奖品所需的关键字卡数,设定规则就可以控制每种奖品所需字卡组合被粉丝集到的数量,规则可以在活动进行中根据需要进行修改,活动规则灵活度高。新版的集卡规则,在此次政府发布号的活动中经受了考验,集到指定字卡组合的粉丝没有超出规则限制。有了这个规则限制后,您无需盯着活动,建好活动后就无人值守让活动进行就行了,您只需要时不时来看下蹭蹭上涨的活动数据即可。 被封? 无需担心,模块内置有防封功能,支持隐藏主域名,显示炮灰域名,保护活动安全进行。 活动准备? 只需要您有一个认证服务号即可,支持订阅号借用认证服务号来做活动。如果您
出口设备线体程序详解:PLC通讯下的V90控制与开源FB284工艺对象实战指南,出口设备线体程序详解:PLC通讯与V90控制集成,工艺对象与FB284协同工作,开源学习V90控制技能,出口设备1200线体程序,多个plc走通讯,内部有多个v90,采用工艺对象与fb284 共同控制,功能快全部开源,能快速学会v90的控制 ,出口设备; 1200线体程序; PLC通讯; 多个V90; 工艺对象; FB284; 功能开源; V90控制。,V90工艺控制:开源功能快,快速掌握1200线体程序与PLC通讯
基于Arduino与DAC8031的心电信号模拟器资料:心电信号与正弦波的双重输出应用方案,Arduino与DAC8031心电信号模拟器:生成心电信号与正弦波输出功能详解,基于arduino +DAC8031的心电信号模拟器资料,可输出心电信号,和正弦波 ,基于Arduino;DAC8031;心电信号模拟器;输出心电信号;正弦波输出;模拟器资料,基于Arduino与DAC8031的心电信号模拟器:输出心电与正弦波
MATLAB口罩检测的基本流程 图像采集:通过摄像头或其他图像采集设备获取包含面部的图像。 图像预处理:对采集到的图像进行灰度化、去噪、直方图均衡化等预处理操作,以提高图像质量,便于后续的人脸检测和口罩检测。 人脸检测:利用Haar特征、LBP特征等经典方法或深度学习模型(如MTCNN、FaceBoxes等)在预处理后的图像中定位人脸区域。 口罩检测:在检测到的人脸区域内,进一步分析是否佩戴口罩。这可以通过检测口罩的边缘、纹理等特征,或使用已经训练好的口罩检测模型来实现。 结果输出:将检测结果以可视化方式展示,如在图像上标注人脸和口罩区域,或输出文字提示是否佩戴口罩。
1、文件内容:kernel-debug-devel-3.10.0-1160.119.1.el7.rpm以及相关依赖 2、文件形式:tar.gz压缩包 3、安装指令: #Step1、解压 tar -zxvf /mnt/data/output/kernel-debug-devel-3.10.0-1160.119.1.el7.tar.gz #Step2、进入解压后的目录,执行安装 sudo rpm -ivh *.rpm 4、更多资源/技术支持:公众号禅静编程坊
该文档提供了一个关于供应链管理系统开发的详细指南,重点介绍了项目安排、技术实现和框架搭建的相关内容。 文档分为以下几个关键部分: 项目安排:主要步骤包括搭建框架(1天),基础数据模块和权限管理(4天),以及应收应付和销售管理(5天)。 供应链概念:供应链系统的核心流程是通过采购商品放入仓库,并在销售时从仓库提取商品,涉及三个主要订单:采购订单、销售订单和调拨订单。 大数据的应用:介绍了数据挖掘、ETL(数据抽取)和BI(商业智能)在供应链管理中的应用。 技术实现:讲述了DAO(数据访问对象)的重用、服务层的重用、以及前端JS的继承机制、jQuery插件开发等技术细节。 系统框架搭建:包括Maven环境的配置、Web工程的创建、持久化类和映射文件的编写,以及Spring配置文件的实现。 DAO的需求和功能:供应链管理系统的各个模块都涉及分页查询、条件查询、删除、增加、修改操作等需求。 泛型的应用:通过示例说明了在Java语言中如何使用泛型来实现模块化和可扩展性。 文档非常技术导向,适合开发人员参考,用于构建供应链管理系统的架构和功能模块。
1.版本:matlab2014/2019a/2024a 2.附赠案例数据可直接运行matlab程序。 3.代码特点:参数化编程、参数可方便更改、代码编程思路清晰、注释明细。 4.适用对象:计算机,电子信息工程、数学等专业的大学生课程设计、期末大作业和毕业设计。
C#与VB实现欧姆龙PLC的Fins TCP通信案例源码:调用动态链接库进行数据读写,定时器与计数器数据区的简洁读写操作示例,C#与VB实现欧姆龙PLC的Fins TCP通信案例源码:调用动态链接库进行读写操作,涵盖定时器计数器数据区学习案例,C#欧姆龙plc Fins Tcp通信案例上位机源码,有c#和VB的Demo,c#上位机和欧姆龙plc通讯案例源码,调用动态链接库,可以实现上位机的数据连接,可以简单实现D区W区定时器计数器等数据区的读写,是一个非常好的学习案例 ,C#; 欧姆龙PLC; Fins Tcp通信; 上位机源码; 动态链接库; 数据连接; D区W区读写; 定时器计数器; 学习案例,C#实现欧姆龙PLC Fins Tcp通信上位机源码,读写数据区高效学习案例
可调谐石墨烯超材料吸收体的FDTD仿真模拟研究报告:吸收光谱的化学势调节策略与仿真源文件解析,可调谐石墨烯超材料吸收体:化学势调节光谱的FDTD仿真模拟研究,可调谐石墨烯超材料吸收体FDTD仿真模拟 【案例内容】该案例提供了一种可调谐石墨烯超材料吸收体,其吸收光谱可以通过改变施加于石墨烯的化学势来进行调节。 【案例文件】仿真源文件 ,可调谐石墨烯超材料吸收体; FDTD仿真模拟; 化学势调节; 仿真源文件,石墨烯超材料吸收体:FDTD仿真调节吸收光谱案例解析
RBF神经网络控制仿真-第二版
松下PLC与威纶通触摸屏转盘设备控制:FPWINPRO7与EBPRO智能编程与宏指令应用,松下PLC与威纶通触摸屏转盘设备控制解决方案:FPWINPRO7与EBPRO协同工作,实现多工位转盘加工与IEC编程模式控制,松下PLC+威纶通触摸屏的转盘设备 松下PLC工程使用程序版本为FPWINPRO7 7.6.0.0版本 威纶通HMI工程使用程序版本为EBPRO 6.07.02.410S 1.多工位转盘加工控制。 2.国际标准IEC编程模式。 3.触摸屏宏指令应用控制。 ,松下PLC; 威纶通触摸屏; 转盘设备控制; 多工位加工控制; IEC编程模式; 触摸屏宏指令应用,松下PLC与威纶通HMI联控的转盘设备控制程序解析
基于循环神经网络(RNN)的多输入单输出预测模型(适用于时间序列预测与回归分析,需Matlab 2021及以上版本),基于循环神经网络(RNN)的多输入单输出预测模型(matlab版本2021+),真实值与预测值对比,多种评价指标与线性拟合展示。,RNN预测模型做多输入单输出预测模型,直接替数据就可以用。 程序语言是matlab,需求最低版本为2021及以上。 程序可以出真实值和预测值对比图,线性拟合图,可打印多种评价指标。 PS:以下效果图为测试数据的效果图,主要目的是为了显示程序运行可以出的结果图,具体预测效果以个人的具体数据为准。 2.由于每个人的数据都是独一无二的,因此无法做到可以任何人的数据直接替就可以得到自己满意的效果。 这段程序主要是一个基于循环神经网络(RNN)的预测模型。它的应用领域可以是时间序列预测、回归分析等。下面我将对程序的运行过程进行详细解释和分析。 首先,程序开始时清空环境变量、关闭图窗、清空变量和命令行。然后,通过xlsread函数导入数据,其中'数据的输入'和'数据的输出'是两个Excel文件的文件名。 接下来,程序对数据进行归一化处理。首先使用ma
1.版本:matlab2014/2019a/2024a 2.附赠案例数据可直接运行matlab程序。 3.代码特点:参数化编程、参数可方便更改、代码编程思路清晰、注释明细。 4.适用对象:计算机,电子信息工程、数学等专业的大学生课程设计、期末大作业和毕业设计。
旅游管理系统中的功能模块主要是实现管理员;首页、个人中心、用户管理、旅游方案管理、旅游购买管理、系统管理,用户;首页、个人中心、旅游方案管理、旅游购买管理、我的收藏管理。前台首页;首页、旅游方案、旅游资讯、个人中心、后台管理等功能。经过认真细致的研究,精心准备和规划,最后测试成功,系统可以正常使用。分析功能调整与旅游管理系统实现的实际需求相结合,讨论了Java开发旅游管理系统的使用。 从上面的描述中可以基本可以实现软件的功能: 1、开发实现旅游管理系统的整个系统程序; 2、管理员;首页、个人中心、用户管理、旅游方案管理、旅游购买管理、系统管理等。 3、用户:首页、个人中心、旅游方案管理、旅游购买管理、我的收藏管理。 4、前台首页:首页、旅游方案、旅游资讯、个人中心、后台管理等相应操作; 5、基础数据管理:实现系统基本信息的添加、修改及删除等操作,并且根据需求进行交流查看及回复相应操作。
Boost二级升压光伏并网结构的Simulink建模与MPPT最大功率点追踪:基于功率反馈的扰动观察法调整电压方向研究,Boost二级升压光伏并网结构的Simulink建模与MPPT最大功率点追踪:基于功率反馈的扰动观察法调整电压方向研究,Boost二级升压光伏并网结构,Simulink建模,MPPT最大功率点追踪,扰动观察法采用功率反馈方式,若ΔP>0,说明电压调整的方向正确,可以继续按原方向进行“干扰”;若ΔP<0,说明电压调整的方向错误,需要对“干扰”的方向进行改变。 ,Boost升压;光伏并网结构;Simulink建模;MPPT最大功率点追踪;扰动观察法;功率反馈;电压调整方向。,光伏并网结构中Boost升压MPPT控制策略的Simulink建模与功率反馈扰动观察法
运行GUI版本,可二开
Deepseek相关主题资源及行业影响
WP Smush Pro 是一款专为 WordPress 网站设计的图像优化插件。 一、主要作用 图像压缩 它能够在不影响图像质量的前提下,大幅度减小图像文件的大小。例如,对于一些高分辨率的产品图片或者风景照片,它可以通过先进的压缩算法,去除图像中多余的数据。通常 JPEG 格式的图像经过压缩后,文件大小可以减少 40% – 70% 左右。这对于网站性能优化非常关键,因为较小的图像文件可以加快网站的加载速度。 该插件支持多种图像格式的压缩,包括 JPEG、PNG 和 GIF。对于 PNG 图像,它可以在保留透明度等关键特性的同时,有效地减小文件尺寸。对于 GIF 图像,也能在一定程度上优化文件大小,减少动画 GIF 的加载时间。 懒加载 WP Smush Pro 实现了图像懒加载功能。懒加载是一种延迟加载图像的技术,当用户滚动页面到包含图像的位置时,图像才会加载。这样可以避免一次性加载大量图像,尤其是在页面内容较多且包含许多图像的情况下。例如,在一个新闻网站的长文章页面,带有大量配图,懒加载可以让用户在浏览文章开头部分时,不需要等待所有图片加载,从而提高页面的初始加载速度,同时也能
Could not create share link. Missing file: C:\Users\xx\.conda\envs\omni\Lib\site-packages\gradio\frpc_windows_amd64_v0.3 1. Download this file: https://cdn-media.huggingface.co/frpc-gradio-0.3/frpc_windows_amd64.exe 2. Rename the downloaded file to: frpc_windows_amd64_v0.3 3. Move the file to this location: C:\Users\xx\.conda\envs\omni\Lib\site-packages\gradio