热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

YII教程-yii流程结构

它是一些常用到的Yii类文件的合并文件。在文件中,注释和跟踪语句都被去除。因此,使用yiilite.php将减少被引用的文件数量并避免执行跟踪语句
一 目录文件
|-framework     框架核心库
|--base         底层类库文件夹,包含CApplication(应用类,负责全局的用户请求处理,它管理的应用组件集,将提供特定功能给整个应用程序),CComponent(组件类,该文件包含了基于组件和事件驱动编程的基础类,从版本1.1.0开始,一个行为的属性(或者它的公共成员变量或它通过getter和/或setter方法??定义的属性)可以通过组件的访问来调用),CBehavior(行为类,主要负责声明事件和相应事件处理程序的方法、将对象的行为附加到组件等等),CModel(模型类,为所有的数据模型提供的基类),CModule(是模块和应用程序的基类,主要负责应用组件和子模块)等等
|--caching      所有缓存方法,其中包含了Memcache缓存,APC缓存,数据缓存,CDummyCache虚拟缓存,CEAcceleratorCache缓存等等各种缓存方法
|--cli          YII项目生成脚本
|--collections  用php语言构造传统OO语言的数据存储单元。如:队列,栈,哈希表等等
|--console      YII控制台
|--db           数据库操作类
|--gii          YII 代码生成器(脚手架),能生成包括模型,控制器,视图等代码
|--i18n         YII 多语言,提供了各种语言的本地化数据,信息、文件的翻译服务、本地化日期和时间格式,数字等
|--logging      日志组件,YII提供了灵活和可扩展的日志记录功能。消息记录可分为根据日志级别和信息类别。应用层次和类别过滤器,可进一步选择的消息路由到不同的目的地,例如文件,电子邮件,浏览器窗口,等等|--messages      提示信息的多语言
|--test          YII提供的测试,包括单元测试和功能测试
|--utils         提供了常用的格式化方法
|--validators    提供了各种验证方法
|--vendors       这个文件夹包括第三方由Yii框架使用的资料库
|--views         提供了YII错误、日志、配置文件的多语言视图
|--web           YII所有开发应用的方法
|---actions      控制器操作类
|---auth         权限认识类,包括身份认证,访问控制过滤,基本角色的访问控制等
|---filters      过滤器,可被配置在控制器动作执行之前或之后执行。例如, 访问控制过滤器将被执行以确保在执行请求的动作之前用户已通过身份验证;性能过滤器可用于测量控制器执行所用的时间
|---form         表单生成方法
|---helpers      视图助手,包含GOOGLE AJAX API,创建HTML,JSON,Javascript相关功能
|---js           JS库
|---renderers    视图渲染组件
|---services     封装SoapServer并提供了一个基于WSDL的Web服务
|---widgets      部件
|---CArrayDataProvider.php       可以配置的排序和分页属性自定义排序和分页的行为
|---CActiveDataProvider.php      ActiveRecord方法类
|---CController.php              控制器方法,主要负责协调模型和视图之间的交互
|---CPagination.php              分页类
|---CUploadedFile.php            上传文件类
|---CUrlManager.php              URL管理
|---CWebModule.php               应用模块管理,应用程序模块可被视为一个独立的子应用
等等方法
|--.htaccess                      重定向文件
|--yii.php                        引导文件
|--YiiBase.php                    YiiBase类最主要的功能是注册了自动加载类方法,加载框架要用到所有接口。
|--yiic                           Yii LINUX 命令行脚本
|--yiic.bat                       YII WINDOW 命令行脚本
|--yiilite.php                    它是一些常用到的 Yii 类文件的合并文件。在文件中,注释和跟踪语句都被去除。因此,使用 yiilite.php 将减少被引用的文件数量并避免执行跟踪语句
二 源码分析
1. 启动
网站的唯一入口程序 index.php :
   1.$yii=dirname(__FILE__).'/../framework/yii.php';
   2.$cOnfig=dirname(__FILE__).'/protected/config/main.php';
   3.
   4.// remove the following line when in production mode
   5. defined('YII_DEBUG')ordefine('YII_DEBUG',true);
   6.
   7.require_once($yii);
   8. Yii::createWebApplication($config)->run();
上面的require_once($yii) 引用出了后面要用到的全局类Yii,Yii类是YiiBase类的完全继承:
   1.classYiiextendsYiiBase
   2. {
   3. }
系统的全局访问都是通过Yii类(即YiiBase类)来实现的,Yii类的成员和方法都是static类型。
2. 类加载
Yii利用PHP5提供的spl库来完成类的自动加载。在YiiBase.php 文件结尾处
   1. spl_autoload_register(array('YiiBase','autoload'));
将YiiBase类的静态方法autoload 注册为类加载器。 PHP autoload 的简单原理就是执行new创建对象或通过类名访问静态成员时,系统将类名传递给被注册的类加载器函数,类加载器函数根据类名自行找到对应的类文件并include。
下面是YiiBase类的autoload方法:
   1.publicstaticfunctionautoload($className)
   2. {
   3.   // use include so that the error PHP file may appear
   4.   if(isset(self::$_coreClasses[$className]))
   5.    include(YII_PATH.self::$_coreClasses[$className]);
   6.   elseif(isset(self::$_classes[$className]))
   7.    include(self::$_classes[$className]);
   8.   else
   9.    include($className.'.php');
  10. }
可以看到YiiBase的静态成员$_coreClasses数组里预先存放着Yii系统自身用到的类对应的文件路径:
   1.privatestatic$_coreClasses=array(
   2.   'CApplication'=>'/base/CApplication.php',
   3.   'CBehavior'=>'/base/CBehavior.php',
   4.   'CComponent'=>'/base/CComponent.php',
   5.    ...
   6. )
非 coreClasse 的类注册在YiiBase的$_classes数组中:
privatestatic$_classes=array();
其他的类需要用Yii::import()讲类路径导入PHPincludepaths 中,直接
include($className.'.php')
3. CWebApplication的创建
回到前面的程序入口的 Yii::createWebApplication($config)->run();
   1.publicstaticfunctioncreateWebApplication($cOnfig=null)
   2. {
   3.   returnnewCWebApplication($config);
   4. }
现在autoload机制开始工作了。
当系统 执行newCWebApplication() 的时候,会自动
include(YII_PATH.'/base/CApplication.php')
将main.php里的配置信息数组$config传递给CWebApplication创建出对象,并执行对象的run() 方法启动框架。
CWebApplication类的继承关系
CWebApplication -> CApplication -> CModule -> CComponent
$config先被传递给CApplication的构造函数
   1.publicfunction__construct($cOnfig=null)
   2. {
   3.    Yii::setApplication($this);
   4.
   5.   // set basePath at early as possible to avoid trouble
   6.   if(is_string($config))
   7.    $cOnfig=require($config);
   8.   if(isset($config['basePath']))
   9.    {
  10.    $this->setBasePath($config['basePath']);
  11.     unset($config['basePath']);
  12.    }
  13.   else
  14.    $this->setBasePath('protected');
  15.    Yii::setPathOfAlias('application',$this->getBasePath());
  16.    Yii::setPathOfAlias('webroot',dirname($_SERVER['SCRIPT_FILENAME']));
  17.
  18.   $this->preinit();
  19.
  20.   $this->initSystemHandlers();
  21.   $this->registerCoreComponents();
  22.
  23.   $this->configure($config);
  24.   $this->attachBehaviors($this->behaviors);
  25.   $this->preloadComponents();
  26.
  27.   $this->init();
  28. }
Yii::setApplication($this); 将自身的实例对象赋给Yii的静态成员$_app,以后可以通过 Yii::app() 来取得。
后面一段是设置CApplication 对象的_basePath ,指向 proteced 目录。
   1. Yii::setPathOfAlias('application',$this->getBasePath());
   2. Yii::setPathOfAlias('webroot',dirname($_SERVER['SCRIPT_FILENAME']));
设置了两个系统路径别名 application 和 webroot,后面再import的时候可以用别名来代替实际的完整路径。别名配置存放在YiiBase的$_aliases数组中。
$this->preinit();
预初始化。preinit()是在 CModule 类里定义的,没有任何动作。
$this->initSystemHandlers() 方法内容:
   1./**
   2. * Initializes the class autoloader and error handlers.
   3. */
   4.protectedfunctioninitSystemHandlers()
   5. {
   6.   if(YII_ENABLE_EXCEPTION_HANDLER)
   7.     set_exception_handler(array($this,'handleException'));
   8.   if(YII_ENABLE_ERROR_HANDLER)
   9.     set_error_handler(array($this,'handleError'),error_reporting()); 
  10. }
设置系统exception_handler和 error_handler,指向对象自身提供的两个方法。
4. 注册核心组件
$this->registerCoreComponents();
代码如下:
   1.protectedfunctionregisterCoreComponents()
   2. {
   3.    parent::registerCoreComponents();
   4.
   5.   $compOnents=array(
   6.    'urlManager'=>array(
   7.     'class'=>'CUrlManager',
   8.     ),
   9.    'request'=>array(
  10.     'class'=>'CHttpRequest',
  11.     ),
  12.    'session'=>array(
  13.     'class'=>'CHttpSession',
  14.     ),
  15.    'assetManager'=>array(
  16.     'class'=>'CAssetManager',
  17.     ),
  18.    'user'=>array(
  19.     'class'=>'CWebUser',
  20.     ),
  21.    'themeManager'=>array(
  22.     'class'=>'CThemeManager',
  23.     ),
  24.    'authManager'=>array(
  25.     'class'=>'CPhpAuthManager',
  26.     ),
  27.    'clientScript'=>array(
  28.     'class'=>'CClientScript',
  29.     ),
  30.    );
  31.
  32.   $this->setComponents($components);
  33. }
注册了几个系统组件(Components)。
Components 是在 CModule 里定义和管理的,主要包括两个数组
   1.private$_compOnents=array();
   2.private$_compOnentConfig=array();
每个 Component 都是 IApplicationComponent接口的实例,Componemt的实例存放在$_components数组里,相关的配置信息存放在$_componentConfig数组里。配置信息包括Component 的类名和属性设置。
CWebApplication 对象注册了以下几个Component:urlManager, request,session,assetManager,user,themeManager,authManager,clientScript。 CWebApplication的parent 注册了以下几个 Component:coreMessages,db,messages,errorHandler,securityManager,statePersister。
Component 在YiiPHP里是个非常重要的东西,它的特征是可以通过 CModule 的 __get() 和 __set() 方法来访问。 Component 注册的时候并不会创建对象实例,而是在程序里被第一次访问到的时候,由CModule 来负责(实际上就是 Yii::app())创建。
5. 处理$config配置
继续,$this->configure($config);
configure() 还是在CModule 里:
   1.publicfunctionconfigure($config)
   2. {
   3.   if(is_array($config))
   4.    {
   5.    foreach($configas$key=>$value)
   6.     $this->$key=$value;
   7.    }
   8. }
实际上是把$config数组里的每一项传给 CModule 的 父类 CComponent __set() 方法。
   1.publicfunction__set($name,$value)
   2. {
   3.   $setter='set'.$name;
   4.   if(method_exists($this,$setter))
   5.    $this->$setter($value);
   6.   elseif(strncasecmp($name,'on',2)===0
   7.                && method_exists($this,$name))
   8.    {
   9.    //duplicating getEventHandlers() here for performance
  10.    $name=strtolower($name);
  11.    if(!isset($this->_e[$name]))
  12.     $this->_e[$name]=newCList;
  13.     $this->_e[$name]->add($value);
  14.     }
  15.    elseif(method_exists($this,'get'.$name))
  16.     thrownewCException(Yii::t('yii','Property "{class}.{property}" is read only.',
  17.     array('{class}'=>get_class($this),'{property}'=>$name)));
  18.    else
  19.     thrownewCException(Yii::t('yii','Property "{class}.{property}" is not defined.',
  20.     array('{class}'=>get_class($this),'{property}'=>$name)));
  21.    }
  22. }
我们来看看:
if(method_exists($this,$setter))
根据这个条件,$config数组里的basePath, params, modules, import, components 都被传递给相应的 setBasePath(), setParams() 等方法里进行处理。
6、$config之 import
其中 import 被传递给 CModule 的 setImport:
   1.publicfunctionsetImport($aliases)
   2. {
   3.   foreach($aliasesas$alias)
   4.     Yii::import($alias);
   5. }
Yii::import($alias)里的处理:
   1.publicstaticfunctionimport($alias,$forceInclude=false)
   2. {
   3.   // 先判断$alias是否存在于YiiBase::$_imports[] 中,已存在的直接return, 避免重复import。
   4.   if(isset(self::$_imports[$alias]))// previously imported
   5.    returnself::$_imports[$alias];
   6.
   7.   // $alias类已定义,记入$_imports[],直接返回
   8.   if(class_exists($alias,false))
   9.    returnself::$_imports[$alias]=$alias;
  10.
  11.   // 类似 urlManager 这样的已定义于$_coreClasses[]的类,或不含.的直接类名,记入$_imports[],直接返回
  12.   if(isset(self::$_coreClasses[$alias]) || ($pos=strrpos($alias,'.'))===false)// a simple class name
  13.    {
  14.     self::$_imports[$alias]=$alias;
  15.    if($forceInclude)
  16.     {
  17.     if(isset(self::$_coreClasses[$alias]))// a core class
  18.      require(YII_PATH.self::$_coreClasses[$alias]);
  19.     else
  20.      require($alias.'.php');
  21.     }
  22.    return$alias;
  23.    }
  24.
  25.   // 产生一个变量 $className,为$alias最后一个.后面的部分
  26.   // 这样的:'x.y.ClassNamer'
  27.   // $className不等于 '*', 并且ClassNamer类已定义的,      ClassNamer' 记入 $_imports[],直接返回
  28.   if(($className=(string)substr($alias,$pos+1))!=='*'&&class_exists($className,false))
  29.    returnself::$_imports[$alias]=$className;
  30.
  31.   // 取得 $alias 里真实的路径部分并且路径有效
  32.   if(($path=self::getPathOfAlias($alias))!==false)
  33.    {
  34.    // $className!=='*',$className 记入 $_imports[]
  35.    if($className!=='*')
  36.     {
  37.      self::$_imports[$alias]=$className;
  38.     if($forceInclude)
  39.      require($path.'.php');
  40.     else
  41.       self::$_classes[$className]=$path.'.php';
  42.     return$className;
  43.     }
  44.    // $alias是'system.web.*'这样的已*结尾的路径,将路径加到include_path中
  45.    else// a directory
  46.     {
  47.      set_include_path(get_include_path().PATH_SEPARATOR.$path);
  48.     returnself::$_imports[$alias]=$path;
  49.     }
  50.    }
  51.   else
  52.    thrownewCException(Yii::t('yii','Alias "{alias}" is invalid. Make sure it points to an existing directory or file.',
  53.     array('{alias}'=>$alias)));
  54. }
7.$config之 components
$config数组里的$components被传递给CModule 的setComponents($components)
   1.publicfunctionsetComponents($components)
   2. {
   3.   foreach($componentsas$id=>$component)
   4.    {
   5.    if($componentinstanceofIApplicationComponent)
   6.     $this->setComponent($id,$component);
   7.    elseif(isset($this->_componentConfig[$id]))
   8.     $this->_componentConfig[$id]=CMap::mergeArray($this->_componentConfig[$id],$component);
   9.    else
  10.     $this->_componentConfig[$id]=$component;
  11.    }
  12. }
$componen是IApplicationComponen的实例的时候,直接赋值:
$this->setComponent($id,$component),
   1.publicfunctionsetComponent($id,$component)
   2. {
   3.   $this->_components[$id]=$component;
   4.   if(!$component->getIsInitialized())
   5.    $component->init();
   6. }
如果$id已存在于_componentConfig[]中(前面注册的coreComponent),将$component属性加进入。
其他的component将component属性存入_componentConfig[]中。
8.$config之 params
这个很简单
   1.publicfunctionsetParams($value)
   2. {
   3.   $params=$this->getParams();
   4.   foreach($valueas$k=>$v)
   5.    $params->add($k,$v);
   6. }
configure 完毕!
9. attachBehaviors
$this->attachBehaviors($this->behaviors);
空的,没动作
预创建组件对象
   1.$this->preloadComponents();
   2.
   3.protectedfunctionpreloadComponents()
   4. {
   5.   foreach($this->preloadas$id)
   6.    $this->getComponent($id);
   7. }
getComponent() 判断_components[] 数组里是否有$id的实例,如果没有,就根据_componentConfig[$id]里的配置来创建组件对象,调用组件的init()方法,然后存入_components[$id]中。
10. init()
$this->init();
函数内:$this->getRequest();
创建了Reques 组件并初始化。
11. run()
   1.publicfunctionrun()
   2. {
   3.   $this->onBeginRequest(newCEvent($this));
   4.   $this->processRequest();
   5.   $this->onEndRequest(newCEvent($this));
   6. }
三 大概过程
application构造函数:
1 设置当前运行实例
2 获取配置参数
3 设置basepath
4 设置几个path;application,webroot ,ext
5 preinit
6 注册error、exception处理函数 initSystemHandlers
7 加载核心组件 registerCoreComponents 包括webapplication的和application的
8 设置配置文件 configure($config)
9 附加行为$this->attachBehaviors($this->behaviors);
10处理加载config中的preload,//通过getComponent分别加载并初始化 $this->preloadComponents();
11 初始化init();//加载CHttpRequest组件
run:
1 处理onBeginRequest
2 processRequest();真正处理请求
3 处理onEndRequest
webapplication->processRequest():
1  如果配置文件设置了catchAllRequest ,// 'catchAllRequest'=>array('site/error','p1'=>'1','p2'=>'2'),
   则所有请求都跳转到这个controller/action这个route,并且设置$_GET参数。
   
2  分析url得到route,便于后面的控制器/动作创建
3  执行runController  
runController:
1 创建controller, createController(),创建失败,则抛出404错误
2 得到controller对象和actionID
3 控制器初始化 $controller->init();
4 最后执行  $controller->run($actionID);//真正执行页面请求
控制器类
CController:默认控制器在CWebApplication::defaultController定义('site'),可以在配置文件修改
run():
1//根据actionID创建action对象,这里生成的action对象分为定义在controller内联动作和自定义action,比如CViewAction
  $action=$this->createAction($actionID),如果创建动作失败,missingAction抛出404错误
2 beforeControllerAction(beforeControllerAction定义在CWebApplication,有时也在module里面)为真,才执行runActionWithFilters;
3 afterControllerAction
runActionWithFilters($action,$this->filters()):
1//如果过滤器为空,直接运行runAction()
2 执行过滤器链
runAction():
1 beforeAction()返回真,才执行
2 执行$action->runWithParams();注意:这里存在多态,每个action都可以实现这个方法, 因为CInlineAction自己实现了runWithParams()
3 第2步骤为真,才执行afterAction($action);
动作类  默认动作在CController::$defaultAction定义('index'),可以在CController的继承类重新定义
runWithParams():
1 分为2种情况,1种是内联动作,1种是通过控制器的actions方法定义的外联动作。
2 内联动作 通过action+动作id作为动作处理函数
3 外联动作 通过调用run()函数来实现
4 如果动作方法参数个数大于0,执行runWithParamsInternal,否则直接执行动作方法。
runWithParamsInternal();
1 根据反射的方法对象得到方法的形参列表,从 控制器对象->getActionParams()得到实参,
  如果实参有形参要求的参数,取其值,不然取形参默认值,否则,出错。
2 调用动作方法   2种形式 1是action+动作id ,2是Caction的派生类(比如cviewaction)的run()
3 执行控制器的CController->render方法;$controller->render($view)
控制器类
CController:
render();
1 renderPartial();得到视图,//先得到contact页面的view文件内容,注意是用include的形式,所以其中的$this是指siteControlerd对象,
  这里调用了renderFile();
2  然后$output=$this->renderFile($layoutFile,array('content'=>$output),true)
   把view中的内容插入到布局页面layouts的column1.php,   'content'和layout的页面的$content变量相关
renderFile();
1 如果程序没有定义viewrender,则执行controller->renderInternal();否则,执行$renderer=Yii::app()->getViewRenderer())->renderFile();
?
发生404错误
errorHandler 在配置文件main中,'errorAction'=>'site/error',
**********************************************************
runActionWithFilters
过滤:
CFilterChain(继承CList,提供数字索引存取功能,遍历)::create($this,$action,$filters)->run();
首先创建过滤链,然后执行过滤
CFilterChain::create($controller,$action,$filters):
1$chain=newCFilterChain($controller,$action);创建一个过滤链$chain
2 根据参数filters数组,遍历创建过滤器$filter(字符串:通过CInlineFilter::create或者 数组:Yii::createComponent),
  并且初始化$filter::init,通过$chain->add($filter)添加到过滤链中,并且返回这个过滤链$chain
注意:如果是字符串,控制器类controller必须要有"filter"+过滤器名的方法。
$chain::run();
1 如果数字索引合法,得到$filter,然后执行$filter->filter($this);
   1.1$filter->filter($this):
       1 执行动作的'filter'+过滤器名称的方法。//比如CController::filterAccessControl($filterChain);
   1.1.1 CController::filterAccessControl($filterChain):
          1$filter=newCAccessControlFilter;//新建过滤器
          2$filter->setRules($this->accessRules());//设置规则
          3$filter->filter($filterChain)  ;//执行过滤
          4$filter->preFilter($filterChain)为真,继续执行$filterChain->run();
          5$filter->postFilter($filterChain);//这个是在动作执行之后过滤
2 否则,说明过滤完毕,$this->controller->runAction($this->action); 直接执行动作。

推荐阅读
  • 本文介绍了如何使用jQuery和AJAX来实现动态更新两个div的方法。通过调用PHP文件并返回JSON字符串,可以将不同的文本分别插入到两个div中,从而实现页面的动态更新。 ... [详细]
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • 本文介绍了数据库的存储结构及其重要性,强调了关系数据库范例中将逻辑存储与物理存储分开的必要性。通过逻辑结构和物理结构的分离,可以实现对物理存储的重新组织和数据库的迁移,而应用程序不会察觉到任何更改。文章还展示了Oracle数据库的逻辑结构和物理结构,并介绍了表空间的概念和作用。 ... [详细]
  • 使用正则表达式爬取36Kr网站首页新闻的操作步骤和代码示例
    本文介绍了使用正则表达式来爬取36Kr网站首页所有新闻的操作步骤和代码示例。通过访问网站、查找关键词、编写代码等步骤,可以获取到网站首页的新闻数据。代码示例使用Python编写,并使用正则表达式来提取所需的数据。详细的操作步骤和代码示例可以参考本文内容。 ... [详细]
  • 在springmvc框架中,前台ajax调用方法,对图片批量下载,如何弹出提示保存位置选框?Controller方法 ... [详细]
  • 本文介绍了前端人员必须知道的三个问题,即前端都做哪些事、前端都需要哪些技术,以及前端的发展阶段。初级阶段包括HTML、CSS、JavaScript和jQuery的基础知识。进阶阶段涵盖了面向对象编程、响应式设计、Ajax、HTML5等新兴技术。高级阶段包括架构基础、模块化开发、预编译和前沿规范等内容。此外,还介绍了一些后端服务,如Node.js。 ... [详细]
  • 微软头条实习生分享深度学习自学指南
    本文介绍了一位微软头条实习生自学深度学习的经验分享,包括学习资源推荐、重要基础知识的学习要点等。作者强调了学好Python和数学基础的重要性,并提供了一些建议。 ... [详细]
  • 在Docker中,将主机目录挂载到容器中作为volume使用时,常常会遇到文件权限问题。这是因为容器内外的UID不同所导致的。本文介绍了解决这个问题的方法,包括使用gosu和suexec工具以及在Dockerfile中配置volume的权限。通过这些方法,可以避免在使用Docker时出现无写权限的情况。 ... [详细]
  • 本文主要解析了Open judge C16H问题中涉及到的Magical Balls的快速幂和逆元算法,并给出了问题的解析和解决方法。详细介绍了问题的背景和规则,并给出了相应的算法解析和实现步骤。通过本文的解析,读者可以更好地理解和解决Open judge C16H问题中的Magical Balls部分。 ... [详细]
  • 知识图谱——机器大脑中的知识库
    本文介绍了知识图谱在机器大脑中的应用,以及搜索引擎在知识图谱方面的发展。以谷歌知识图谱为例,说明了知识图谱的智能化特点。通过搜索引擎用户可以获取更加智能化的答案,如搜索关键词"Marie Curie",会得到居里夫人的详细信息以及与之相关的历史人物。知识图谱的出现引起了搜索引擎行业的变革,不仅美国的微软必应,中国的百度、搜狗等搜索引擎公司也纷纷推出了自己的知识图谱。 ... [详细]
  • MACElasticsearch安装步骤及验证方法
    本文介绍了MACElasticsearch的安装步骤,包括下载ZIP文件、解压到安装目录、启动服务,并提供了验证启动是否成功的方法。同时,还介绍了安装elasticsearch-head插件的方法,以便于进行查询操作。 ... [详细]
  • 本文介绍了一种处理AJAX操作授权过期的全局方式,以解决Asp.net MVC中Session过期异常的问题。同时还介绍了基于WebImage的图片上传工具类。详细内容请参考链接:https://www.cnblogs.com/starluck/p/8284949.html ... [详细]
  • 在Android中解析Gson解析json数据是很方便快捷的,可以直接将json数据解析成java对象或者集合。使用Gson解析json成对象时,默认将json里对应字段的值解析到java对象里对应字段的属性里面。然而,当我们自己定义的java对象里的属性名与json里的字段名不一样时,我们可以使用@SerializedName注解来将对象里的属性跟json里字段对应值匹配起来。本文介绍了使用@SerializedName注解解析json数据的方法,并给出了具体的使用示例。 ... [详细]
  • 本文介绍了如何使用JSONObiect和Gson相关方法实现json数据与kotlin对象的相互转换。首先解释了JSON的概念和数据格式,然后详细介绍了相关API,包括JSONObject和Gson的使用方法。接着讲解了如何将json格式的字符串转换为kotlin对象或List,以及如何将kotlin对象转换为json字符串。最后提到了使用Map封装json对象的特殊情况。文章还对JSON和XML进行了比较,指出了JSON的优势和缺点。 ... [详细]
  • express工程中的json调用方法
    本文介绍了在express工程中如何调用json数据,包括建立app.js文件、创建数据接口以及获取全部数据和typeid为1的数据的方法。 ... [详细]
author-avatar
diy2099_d94639
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有