thinkphp笔记,thinkphp
thinkphp笔记,thinkphp
M 项目目录/应用目录/Lib/Model V 项目目录/应用目录/Tpl C 项目目录/应用目录/Lib/Action 1.PATHINFO 模式 http://域名/项目名/入口文件/模块名/方法名/键1/值1/键2/值2 2.普通模式 http://域名/项目名/入口文件?m=模块名&a=方法名&键1=值1&键2=值2 3.REWRITE模块 http://域名/项目名/模块名/方法名/键1/值1/键2/值2 4.兼容模式 http://域名/项目名/入口文件?s=模块名/方法名/键1/值1/键2/值2 // 本类由系统自动生成,仅供测试用途class IndexAction extends Action {
public function index(){
echo "hello world";
}
public function add(){
echo "你好,吴昊
";
echo '你好'.$_GET['name'].'你的年龄是'.$_GET['age'];
}
} http://localhost/test/index.php/Index/add?name=wuhao http://localhost/test/index.php/Index/add/name/wuhao http://localhost/test/index.php/Index/add/name/wuhao/age/18
'URL_PATHINFO_DEPR'=>'-', //修改URL的分隔符
'TMPL_L_DELIM'=>' 'TMPL_R_DELIM'=>'}>', //修改右定界符 http://localhost/test/index.php/Index-add-name-wuhao-age-23 http://localhost/test/index.php/Index/indexhttp://localhost/test/index.php/Index/add public function add(){ /*echo "你好,吴昊
"; echo '你好'.$_GET['name'].'你的年龄是'.$_GET['age'];*/ $name='吴昊'; $this->assign('myname',$name); //$this->myname='abc'; $this->display(); }
一些动态的数据可以通过assign()方法分配给模板显示
访问了add方法。
你好!{$myname}
D:\wamp\www\test\App\Tpl\Index 需要在方法中通过new Model(表名)的形式操作数据库 $m=new Model('User'); $arr=$m->select(); 'DB_TYPE'=>'mysql', //设置数据库类型'DB_HOST'=>'localhost',//设置主机 'DB_NAME'=>'thinkphp',//设置数据库名 'DB_USER'=>'root', //设置用户名 'DB_PWD'=>'', //设置密码 'DB_PORT'=>'3306', //设置端口号 'DB_PREFIX'=>'tp_', //设置表前缀 'DB_DSN'=>'mysql://root:@localhost:3306/thinkphp',//使用DSN方式配置数据库信息 ,优先级比传统方式高
$user=new Model('User'); $arr=$user->select(); var_dump($arr); $this->display(); 'SHOW_PAGE_TRACE'=>true,//开启页面Trace 还有一种简单实用模型的方式 M() 等效为 new Model(); $m=M('User'); $arr=$m->select(); 使用模型的实例可以对数据进行操作,操作的工作一般就是对数据库进行 增删改查 CURD 增 -C Create $m->add() 删 -D Delete $m->delete() 改 -U Update $m->save() 查 -R Read $m->select() a、模板可以遍历数组
b、我们可以开启调试功能中的page_trace 1.开启调试功能 define('APP_DEBUG',true); 2.我们需要设置配置文件,开启页面trace 'SHOW_PAGE_TRACE'=>true,//开启页面Trace 读取数据 对数据的读取 Read $m=new Model('User'); $m=M('User'); select:$m->select(); //获取所有数据,以数组形式返回 find:$m->find($id); //获取单条数据 getField(字段名) //获取一个具体的字段值 $arr=$m->where('id=2')->getField('username'); 创建数据 对数据的添加 Create $m=new Model('User'); $m=M('User'); $m->字段名=值 $m->add(); 返回值是新增的id号 删除数据 $m=M('User'); $m->delete(2); //删除id为2的数据 $m->where('id=2')->delete(); 返回值是受影响行数 更新数据 $m=M('User'); $data['id']=1; $data['username']='ztz2'; $m->save($data); 返回值是受影响行数 CURD演示: ================================================================================================================================================================================================== 查询方式: 一、普通查询方式 a、字符串 $arr=$m->where("sex=0 and username='gege'")->find(); b、数组 $data['sex']=0; $data['username']='gege'; $arr=$m->where($data)->find(); 注意:这种方式默认是and的关系,如果使用or关系,需要添加数组值:$data['_logic']='or'; 二、表达式查询方式 $data['id']=array('lt',6); $arr=$m->where($data)->select(); EQ 等于,NEQ不等于, GT 大于,EGT大于等于, LT 小于,ELT小于等于,LIKE 模糊查询 $data['username']=array('like','%ge'); $arr=$m->where($data)->select(); NOTLIKE $data['username']=array('notlike','%ge%'); $arr=$m->where($data)->select(); 注意:如果一个字段要匹配多个通配符 $data['username']=array('like',array('%ge%','%2%','%五%'),'and'); //如果没有第三个值,默认关系是or关系 BETWEEN $data['id']=array('between',array(5,7)); $arr=$m->where($data)->select(); //SELECT * FROM `tp_user` WHERE ( (`id` BETWEEN 5 AND 7 ) ) $data['id']=array('not between',array(5,7)); $arr=$m->where($data)->select(); IN $data['id']=array('in',array(4,6,7)); $arr=$m->where($data)->select(); //SELECT * FROM `tp_user` WHERE ( `id` IN (4,6,7) ) $data['id']=array('not in',array(4,6,7)); $arr=$m->where($data)->select(); //SELECT * FROM `tp_user` WHERE ( `id` NOT IN (4,6,7) ) 三、区间查询 $data['id']=array(array('gt',4),array('lt',10)); //默认关系是 and 的关系 //SELECT * FROM `tp_user` WHERE ( (`id` > 4) AND (`id` $data['id']=array(array('gt',4),array('lt',10),'or') //关系就是or的关系 $data['name']=array(array('like','%2%'),array('like','%五%'),'gege','or'); 四、统计查询 count //获取个数;max //获取最大数;min //获取最小数;avg //获取平均数;sum //获取总和 五、SQL直接查询 a、query 主要是处理读取数据的:成功返回数据的结果集,失败返回boolean false $m=M(); $result=$m->query("select * from t_user where id >50"); var_dump($result); b、execute 用于更新个写入操作:成功返回影响行数,失败返回boolean false $m=M(); $result=$m->execute("insert into t_user(`username`) values('ztz3')"); var_dump($result); 'DB_LIKE_FIELDS'=>'title|content' //查询语句中条件自动变为模糊查询%% 查询方式演示: ================================================================================================================================================================================================== 常用连贯操作 1.where 帮助我们设置查询条件 2.order 对结果进行排序 $arr=$m->order('id desc')->select(); $arr=$m->order(array('id'=>'desc','sex'=>'asc'))->select(); 3.limit 限制结果 limit(2,5) limit('2,5') limit(10) //limit(0,10) 4.field 设置查询字段 field('username as name,id') field(array('username'=>'name','id') field('id',true) //获取除了id以外的所有字段 5.table 6.group 7.having 二、补充 alias 用于给当前数据表定义别名 字符串 page 用于查询分页(内部会转换成limit) 字符串和数字 join* 用于对查询的join支持 字符串和数组 union* 用于对查询的union支持 字符串、数组和对象 distinct 用于查询的distinct支持 布尔值 lock 用于数据库的锁机制 布尔值 cache 用于查询缓存 支持多个参数(以后在缓存部分再详细描述) relation 用于关联查询(需要关联模型扩展支持) 字符串 validate 用于数据自动验证 数组 auto 用于数据自动完成 数组 filter 用于数据过滤 字符串 scope* 用于命名范围 字符串、数组 ================================================================================================================================================================================================== 视图: 一、模板的使用 a、规则 模板文件夹下[TPL]/[分组文件夹/][模板主题文件夹/]和模块名同名的文件夹[Index]/和方法名同名的文件[index].html(.tpl) 更换模板文件的后缀名(修改配置文件) 'TMPL_TEMPLATE_SUFFIX'=>'.html', //更改模板文件后缀名 b、修改模板文件目录层次 'TMPL_FILE_DEPR'=>'_', //修改模板文件目录层次 c、模板主题 'DEFAULT_THEME'=>'your', //设置默认模板主题 需要在TPL下面新建一个your文件夹作为模板主题文件夹 如何动态修改模板主题? 1、在后台准备一个功能,修改config.php文件中的默认模板项 2、通过url传递 t=主题 参数可以修改不同的模板 'DEFAULT_THEME'=>'your',//设置默认模板主题 'TMPL_DETECT_THEME'=>true,//自动侦测模板主题 'THEME_LIST'=>'your,my',//支持的模板主题列表 http://localhost/test/index.php/Index/index/t/my http://localhost/test/index.php/Index/index/t/you 二、输出模板内容 a、display 1.display中没有参数:$this->display(); 2.可以带参数 $this->display(本模块文件夹下的其他模板文件); $this->display('index2'); $this->display(其他文件夹下的模板文件); $this->display('Public:error'); //注意,仅仅需要在Tpl下有Public文件夹以及其中的error.html即可,不需要一定有Public模块 $this->display(其他主题下的 文件夹下的 模板文件); //需要开启主题支持 $this->display('my:Index:index'); $this->display(一个URL路径); $this->display('./Public/error.html'); $this->display('./Public/error.html','utf-8','text/xml'); $this->show($content); 3.fetch方法 获得模板文件中的内容,以字符串形式返回:$content=$this->fetch('Public:error'); 4.show方法 不需要模板文件,可以直接输出模板内容 $content=$this->fetch('Public:error'); dump($content); $content=str_replace('h1','i',$content); $this->show($content); 三、模板中的赋值 //$this->assign('name','赵桐正'); $this->name='赵桐正2'; $this->display(); 四、模板替换 __PUBLIC__:会被替换成当前网站的公共目录 通常是 /Public/ __ROOT__: 会替换成当前网站的地址(不含域名) __APP__: 会替换成当前项目的URL地址 (不含域名) __GROUP__:会替换成当前分组的URL地址 (不含域名) __URL__: 会替换成当前模块的URL地址(不含域名) __ACTION__:会替换成当前操作的URL地址 (不含域名) __SELF__: 会替换成当前的页面URL 更换模板变量规则,修改配置项 'TMPL_PARSE_STRING'=>array( //添加自己的模板变量规则 '__CSS__'=>__ROOT__.'/Public/Css', '__JS__'=>__ROOT__.'/Public/Js', ), 登录框实例: 引入扩展类,把ThinkPHP3.1.2_Extend里面的文件放在D:\wamp\www\test\ThinkPHP\Extend文件夹下。 对应的js和css: D:\wamp\www\test\Public\Css ·D:\wamp\www\test\Public\Js ================================================================================================================================================================================================== 模板中的变量: 一、变量输出 1.标量输出 2.数组输出 {$name[1]} {$name['k2']} {$name.k1} 3.对象输出 {$name:k} {$name->k} 二、系统变量
用法 | 含义 | 例子 |
---|---|---|
$Think.server | 获取$_SERVER | {$Think.server.php_self} |
$Think.get | 获取$_GET | {$Think.get.id} |
$Think.post | 获取$_POST | {$Think.post.name} |
$Think.request | 获取$_REQUEST | {$Think.request.user_id} |
$Think.cookie | 获取$_COOKIE | {$Think.cookie.username} |
$Think.session | 获取$_SESSION | {$Think.session.user_id} |
$Think.config | 获取系统配置参数 | {$Think.config.app_status} |
$Think.lang | 获取系统语言变量 | {$Think.lang.user_type} |
$Think.const | 获取系统常量 | {$Think.const.app_name}或{$Think.APP_NAME} |
$Think.env | 获取环境变量 | {$Think.env.HOSTNAME} |
$Think.version | 获取框架版本号 | {$Think.version} |
$Think.now | 获取当前时间 | {$Think.now} |
$Think.template | 获取当前模板 | {$Think.template} |
$Think.ldelim | 获取模板左界定符 | {$Think.ldelim} |
$Think.rdelim | 获取模板右界定符 | {$Think.rdelim} |
{$j} | abc |
3.foreach $user=M('User1'); $arr=$user->select(); $this->assign('list',$arr); $this->display();
这里是渲染页面!!!
{__CONTENT__}
핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











ThinkPHP 프로젝트를 실행하려면 다음이 필요합니다: Composer를 설치하고, 프로젝트 디렉터리를 입력하고 php bin/console을 실행하고, 시작 페이지를 보려면 http://localhost:8000을 방문하세요.

ThinkPHP에는 다양한 PHP 버전용으로 설계된 여러 버전이 있습니다. 메이저 버전에는 3.2, 5.0, 5.1, 6.0이 포함되며, 마이너 버전은 버그를 수정하고 새로운 기능을 제공하는 데 사용됩니다. 최신 안정 버전은 ThinkPHP 6.0.16입니다. 버전을 선택할 때 PHP 버전, 기능 요구 사항 및 커뮤니티 지원을 고려하십시오. 최상의 성능과 지원을 위해서는 최신 안정 버전을 사용하는 것이 좋습니다.

ThinkPHP Framework를 로컬에서 실행하는 단계: ThinkPHP Framework를 로컬 디렉터리에 다운로드하고 압축을 풉니다. ThinkPHP 루트 디렉터리를 가리키는 가상 호스트(선택 사항)를 만듭니다. 데이터베이스 연결 매개변수를 구성합니다. 웹 서버를 시작합니다. ThinkPHP 애플리케이션을 초기화합니다. ThinkPHP 애플리케이션 URL에 접속하여 실행하세요.

Laravel과 ThinkPHP 프레임워크의 성능 비교: ThinkPHP는 일반적으로 최적화 및 캐싱에 중점을 두고 Laravel보다 성능이 좋습니다. Laravel은 잘 작동하지만 복잡한 애플리케이션의 경우 ThinkPHP가 더 적합할 수 있습니다.

ThinkPHP 설치 단계: PHP, Composer 및 MySQL 환경을 준비합니다. Composer를 사용하여 프로젝트를 만듭니다. ThinkPHP 프레임워크와 종속성을 설치합니다. 데이터베이스 연결을 구성합니다. 애플리케이션 코드를 생성합니다. 애플리케이션을 실행하고 http://localhost:8000을 방문하세요.

"개발 제안: ThinkPHP 프레임워크를 사용하여 비동기 작업을 구현하는 방법" 인터넷 기술의 급속한 발전으로 인해 웹 응용 프로그램은 많은 수의 동시 요청과 복잡한 비즈니스 논리를 처리하기 위한 요구 사항이 점점 더 높아졌습니다. 시스템 성능과 사용자 경험을 향상시키기 위해 개발자는 이메일 보내기, 파일 업로드 처리, 보고서 생성 등과 같이 시간이 많이 걸리는 작업을 수행하기 위해 비동기 작업을 사용하는 것을 종종 고려합니다. PHP 분야에서 널리 사용되는 개발 프레임워크인 ThinkPHP 프레임워크는 비동기 작업을 구현하는 몇 가지 편리한 방법을 제공합니다.

ThinkPHP는 캐싱 메커니즘, 코드 최적화, 병렬 처리 및 데이터베이스 최적화와 같은 장점을 갖춘 고성능 PHP 프레임워크입니다. 공식 성능 테스트에 따르면 초당 10,000개 이상의 요청을 처리할 수 있으며 JD.com, Ctrip과 같은 대규모 웹 사이트 및 엔터프라이즈 시스템에서 실제 응용 프로그램으로 널리 사용됩니다.

ThinkPHP6 백엔드 관리 시스템 개발: 백엔드 기능 구현 소개: 인터넷 기술과 시장 수요의 지속적인 발전으로 인해 점점 더 많은 기업과 조직에서 비즈니스 데이터를 관리하고 운영 관리를 수행하기 위해 효율적이고 안전하며 유연한 백엔드 관리 시스템이 필요합니다. 이 기사에서는 ThinkPHP6 프레임워크를 사용하여 권한 제어, 데이터 추가, 삭제, 수정 및 쿼리와 같은 기본 기능을 포함하여 간단하지만 실용적인 백엔드 관리 시스템을 개발하는 방법을 예제를 통해 보여줍니다. 환경 준비 시작하기 전에 PHP, MySQL, Com을 설치해야 합니다.
