Symfoy2 是什么(转),symfoy2
Symfoy2 是什么(转),symfoy2
本文转自:http://www.cnblogs.com/Seekr/archive/2012/06/15/2550894.html
Symfoy2 是什么?
PHP世界里又一广受关注的web MVC框架? Fabien Potencier 却不这么说!
Fabien Potencier这样定义Symfoy2 是个什么东西:
首先,Symfony2 是一个独立,松散的,有组织严密的PHP组件集合,它可以为你解决一些web开发中遇到的一般性问题。
其次,基于这些组件,Symfoy2 也可以作为一个独立的web框架使用。
那么Symfony2 是一个MVC框架吗?
Fabien Potencier 说Symfony2从来没有把自己定义为一个MVC框架!
那它是什么? Fabien Potencier 我们从来不关心MVC模式,关心的只有各个关注点的分离(separation of concerns)。
但是Symfony2 还是提供了部分的MVC模式的实现:比如Controller部分,View部分却没有Mode部分不过你可以通过和它紧密继承的ORM(Doctrine2和Propel)实现。
从这个角度看Symfony的确也没有逃出web MVC框架的圈子啊!!!
Fabien Potencier 又说Symfony2从来就没有想靠这些ORM来使自己成为另一个MVC的追随者,我们的目标更远大!
告诉你吧, Symfony2 是一个HTTP框架或者说是一个Request/Response 框架。我们紧盯的目标不是MVC模式,而是HTTP协议,我们是更低级的更基础的框架。
我们为什么要这么说呢? 有根据的!
近几年随着web的发展,有时候你只需要创建一组REST API,所有的逻辑都放到浏览器端,服务器端只提供数据就是一种web了。不信你看 backbone.js !
再说了,MVC模式只不过是Web 应用程序的其中一种实现方式罢了。
剥去所有框架模式的皮,你看看那个web程序不是处理一个接收到的Request然后返回一个Response啊?
我们Symfony2 抓住的就是web程序的根本! 再说我们众多的HTTP流媒体有哪个会选择使用MVC呢?
总之,我们Symfony2比MVC更靠近根本,我们更底层,更通用!!!
说起Symfony2,Fabien Potencier说我们有着更加远大的目标,怎么解释呢?
Symfony2 将继续专注于Pack技术的研究和创新!我们相信她会继续推动web的向前发展。
先看看Symfony2 中我们已经包含的创新吧!
从Bundles,HTTP 缓存,分布式,依赖注入,模板引擎,声明式配置,资产管理,稳定的API到web分析器等等一系列技术都对web的发展起到了巨大的推动作用。
“ 要知道一个独立的框架永远不可能成为PHP世界里的一个标准,所以Symfony2 在探寻另外一条路!”
“ 共享无处不在。”
“ 我们不能重复制造轮子。”
因此,我们紧密的集成了Monolog,Composer,Doctrine,Propel,Assetic,Twig,Swiftmailer等伟大产品。
更重要的是我们想跟大家分享我们的工作!
所以,我们最终选择了走组件(components)化这条路!
我们将为一切web项目提供建筑模块,无论是个人项目还是商业项目,更或者是开源项目!
据说在Symfony2 的代码中可能会有标志为@api的类或者方法,它意味着一个方法从名字到参数以及返回值都不会因为Symfony2发展版本而变化,所以,如果
你的项目只使用了这些,那么你就不用担心Symfony2的版本升级问题。
看看Symfony2 现在拥有的组件吧:
DependencyInjection
EventDispatcher
HttpFoundation
DomCrawler
ClassLoader
CssSelector
HttpKernel
BrowserKit
Templating
Translation
Serializer
Validator
Security
Routing
Console
Process
Config
Finder
Locale
Yaml
Form
Fabien 简单介绍了几个bundle:
1. ClassLoader:
实现了PSR-o 标准(自动加载具有命名空间的类,适用于PHP5.3以上)的自动加载器,同时它也能按照PEAR命名规则加载类。它非常灵活可以基于子命名空间在不同的目录中查询要加载的类。你甚至可以为一个命名空间指定多个目录。
<span> 1</span> <span>require_once</span> __DIR__.'/src/Symfony/Component/ClassLoader/UniversalClassLoader.php'<span>; </span><span> 2</span> <span> 3</span> <span>use</span><span> Symfony\Component\ClassLoader\UniversalClassLoader; </span><span> 4</span> <span> 5</span> <span>$loader</span> = <span>new</span><span> UniversalClassLoader(); </span><span> 6</span> <span>$loader</span>->registerNamespaces(<span>array</span><span>( </span><span> 7</span> 'Symfony' => <span>array</span>(__DIR__.'/src', __DIR__.'/symfony/src'), <span> 8</span> 'Doctrine\\Common' => __DIR__.'/vendor/doctrine-common/lib', <span> 9</span> 'Doctrine\\DBAL' => __DIR__.'/vendor/doctrine-dbal/lib', <span>10</span> 'Doctrine' => __DIR__.'/vendor/doctrine/lib', <span>11</span> 'Monolog' => __DIR__.'/vendor/monolog/src', <span>12</span> <span>)); </span><span>13</span> <span>$loader</span>->registerPrefixes(<span>array</span><span>( </span><span>14</span> 'Twig_' => __DIR__.'/vendor/twig/lib', <span>15</span> <span>)); </span><span>16</span> <span>$loader</span>->register();
如果你想获取更加高的执行效率,可以选择使用APC缓存版Universal类加载器。
2.Console 命令行工具
在创建web应用程序时使用命令行工具很方便,你可以想如下代码一样创建自己的命令行工具:
<span> 1</span> <span>use</span><span> Symfony\Component\Console\Application; </span><span> 2</span> <span>use</span><span> Symfony\Component\Console\Input\InputInterface; </span><span> 3</span> <span>use</span><span> Symfony\Component\Console\Input\InputArgument; </span><span> 4</span> <span>use</span><span> Symfony\Component\Console\Input\InputOption; </span><span> 5</span> <span>use</span><span> Symfony\Component\Console\Output\OutputInterface; </span><span> 6</span> <span> 7</span> <span>$console</span> = <span>new</span><span> Application(); </span><span> 8</span> <span>$console</span> <span> 9</span> ->register('ls'<span>) </span><span>10</span> ->setDefinition(<span>array</span><span>( </span><span>11</span> <span>new</span> InputArgument('dir', InputArgument::REQUIRED, 'Directory name'), <span>12</span> <span> )) </span><span>13</span> ->setDescription('Displays the files in the given directory'<span>) </span><span>14</span> ->setCode(<span>function</span> (InputInterface <span>$input</span>, OutputInterface <span>$output</span><span>) { </span><span>15</span> <span>$dir</span> = <span>$input</span>->getArgument('dir'<span>); </span><span>16</span> <span>17</span> <span>$output</span>->writeln(<span>sprintf</span>('Dir listing for <info>%s</info>', <span>$dir</span><span>)); </span><span>18</span> <span> }) </span><span>19</span> <span>; </span><span>20</span> <span>$console</span>->run();
3.YAML 一种现在很流行的配置格式。
<span>use</span><span> Symfony\Component\Yaml\Yaml; </span><span>$array</span> = Yaml::parse(<span>$file</span><span>); </span><span>print</span> Yaml::dump(<span>$array</span>);
4. Finder 优秀文件资源的操作接口。
<span> 1</span> <span>use</span><span> Symfony\Component\Finder\Finder; </span><span> 2</span> <span> 3</span> <span>$finder</span> = <span>new</span><span> Finder(); </span><span> 4</span> <span> 5</span> <span>$iterator</span> = <span>$finder</span> <span> 6</span> -><span>files() </span><span> 7</span> ->name('*.php'<span>) </span><span> 8</span> ->depth(0<span>) </span><span> 9</span> ->size('>= 1K'<span>) </span><span>10</span> -><span>in(__DIR__); </span><span>11</span> <span>12</span> <span>foreach</span> (<span>$iterator</span> <span>as</span> <span>$file</span><span>) { </span><span>13</span> <span>print</span> <span>$file</span>->getRealpath()."\n"<span>; </span><span>14</span> }
你甚至可以用它获取远程服务器文件系统中的资源,比如获取Amazon S3上的文件:
<span>1</span> <span>$s3</span> = <span>new</span> \Zend_Service_Amazon_S3(<span>$key</span>, <span>$secret</span><span>); </span><span>2</span> <span>$s3</span>->registerStreamWrapper("s3"<span>); </span><span>3</span> <span>4</span> <span>$finder</span> = <span>new</span><span> Finder(); </span><span>5</span> <span>$finder</span>->name('photos*')->size('< 100K')-><span>date</span>('since 1 hour ago'<span>); </span><span>6</span> <span>foreach</span> (<span>$finder</span>->in('s3://bucket-name') <span>as</span> <span>$file</span><span>) { </span><span>7</span> <span>print</span> <span>$file</span>->getFilename()."\n"<span>; </span><span>8</span> }
5.Process 进程组件,你可以用来在一个外部进程中执行命令!下面例子是执行一个简单的目录列表命令并返回结果:
<span> 1</span> <span>use</span><span> Symfony\Component\Process\Process; </span><span> 2</span> <span> 3</span> <span>$process</span> = <span>new</span> Process('ls -lsa'<span>); </span><span> 4</span> <span>$process</span>->setTimeout(3600<span>); </span><span> 5</span> <span>$process</span>-><span>run(); </span><span> 6</span> <span>if</span> (!<span>$process</span>-><span>isSuccessful()) { </span><span> 7</span> <span>throw</span> <span>new</span> RuntimeException(<span>$process</span>-><span>getErrorOutput()); </span><span> 8</span> <span>} </span><span> 9</span> <span>10</span> <span>print</span> <span>$process</span>->getOutput();
如果你想监控执行过程,你可以给run方法传入一个匿名方法:
<span> 1</span> <span>use</span><span> Symfony\Component\Process\Process; </span><span> 2</span> <span> 3</span> <span>$process</span> = <span>new</span> Process('ls -lsa'<span>); </span><span> 4</span> <span>$process</span>->run(<span>function</span> (<span>$type</span>, <span>$buffer</span><span>) { </span><span> 5</span> <span>if</span> ('err' === <span>$type</span><span>) { </span><span> 6</span> <span>echo</span> 'ERR > '.<span>$buffer</span><span>; </span><span> 7</span> } <span>else</span><span> { </span><span> 8</span> <span>echo</span> 'OUT > '.<span>$buffer</span><span>; </span><span> 9</span> <span> } </span><span>10</span> });
6.DomCrawler jQuery的php版本!你可以用它导航定位HTML的DOM结构或者XML文档。
<span>1</span> <span>use</span><span> Symfony\Component\DomCrawler\Crawler; </span><span>2</span> <span>3</span> <span>$crawler</span> = <span>new</span><span> Crawler(); </span><span>4</span> <span>$crawler</span>->addContent('<html><body><p>Hello World!</p></body></html>'<span>); </span><span>5</span> <span>6</span> <span>print</span> <span>$crawler</span>->filterXPath('descendant-or-self::body/p')->text();
7.CssSelector 我们经常用XPath来访问Dom结构,其实用Css 选择器更加容易,这个组件就是把Css选择器转为XPath等效的东西。
<span>1</span> <span>use</span><span> Symfony\Component\CssSelector\CssSelector; </span><span>2</span> <span>3</span> <span>print</span> CssSelector::toXPath('div.item > h4 > a');
所以你可以使用CssSelector 和DomCrawler来替代XPath:
<span>1</span> <span>use</span><span> Symfony\Component\DomCrawler\Crawler; </span><span>2</span> <span>3</span> <span>$crawler</span> = <span>new</span><span> Crawler(); </span><span>4</span> <span>$crawler</span>->addContent('<html><body><p>Hello World!</p></body></html>'<span>); </span><span>5</span> <span>6</span> <span>print</span> <span>$crawler</span>->filter('body > p')->text();
8.HttpFoundation
该组件只是在PHP的相关web内容上面增加了一个面向对象层,包括Request,Response,Uploaded files,Cookies,Sessions...
<span>1</span> <span>use</span><span> Symfony\Component\HttpFoundation\Request; </span><span>2</span> <span>use</span><span> Symfony\Component\HttpFoundation\Response; </span><span>3</span> <span>4</span> <span>$request</span> = Request::<span>createFromGlobals(); </span><span>5</span> <span>echo</span> <span>$request</span>->getPathInfo();
你用它可以很容易的创建自己的Request 和 Response:
<span>1</span> <span>$request</span> = Request::create('/?foo=bar', 'GET'<span>); </span><span>2</span> <span>echo</span> <span>$request</span>-><span>getPathInfo(); </span><span>3</span> <span>4</span> <span>5</span> <span>$response</span> = <span>new</span> Response('Not Found', 404, <span>array</span>('Content-Type' => 'text/plain'<span>)); </span><span>6</span> <span>$response</span>->send();
9.Routing
路由组件和Request对象是相互配合着把Request转换为Response。
<span> 1</span> <span>use</span><span> Symfony\Component\HttpFoundation\Request; </span><span> 2</span> <span>use</span><span> Symfony\Component\Routing\Matcher\UrlMatcher; </span><span> 3</span> <span>use</span><span> Symfony\Component\Routing\RequestContext; </span><span> 4</span> <span>use</span><span> Symfony\Component\Routing\RouteCollection; </span><span> 5</span> <span>use</span><span> Symfony\Component\Routing\Route; </span><span> 6</span> <span> 7</span> <span>$routes</span> = <span>new</span><span> RouteCollection(); </span><span> 8</span> <span>$routes</span>->add('hello', <span>new</span> Route('/hello', <span>array</span>('controller' => 'foo'<span>))); </span><span> 9</span> <span>10</span> <span>$context</span> = <span>new</span><span> RequestContext(); </span><span>11</span> <span>12</span> <span>//</span><span> this is optional and can be done without a Request instance</span> <span>13</span> <span>$context</span>->fromRequest(Request::<span>createFromGlobals()); </span><span>14</span> <span>15</span> <span>$matcher</span> = <span>new</span> UrlMatcher(<span>$routes</span>, <span>$context</span><span>); </span><span>16</span> <span>17</span> <span>$parameters</span> = <span>$matcher</span>->match('/hello');
10.EventDispatcher
<span> 1</span> <span>use</span><span> Symfony\Component\EventDispatcher\EventDispatcher; </span><span> 2</span> <span>use</span><span> Symfony\Component\EventDispatcher\Event; </span><span> 3</span> <span> 4</span> <span>$dispatcher</span> = <span>new</span><span> EventDispatcher(); </span><span> 5</span> <span> 6</span> <span>$dispatcher</span>->addListener('event_name', <span>function</span> (Event <span>$event</span><span>) { </span><span> 7</span> <span>//</span><span> ...</span> <span> 8</span> <span>}); </span><span> 9</span> <span>10</span> <span>$dispatcher</span>->dispatch('event_name');
11.DependencyInjection
<span>use</span><span> Symfony\Component\DependencyInjection\ContainerBuilder; </span><span>use</span><span> Symfony\Component\DependencyInjection\Reference; </span><span>$sc</span> = <span>new</span><span> ContainerBuilder(); </span><span>$sc</span> ->register('foo', '%foo.class%'<span>) </span>->addArgument(<span>new</span> Reference('bar'<span>)) ; </span><span>$sc</span>->setParameter('foo.class', 'Foo'<span>); </span><span>$sc</span>->get('foo');
12.HttpKernel
Http 内核组件提供了HTTP协议中最有活力的部分,以下面接口的形式定义展示,它也是Symfony2框架的核心。
<span> 1</span> <span>interface</span><span> HttpKernelInterface </span><span> 2</span> <span>{ </span><span> 3</span> <span>/*</span><span>* </span><span> 4</span> <span> * Handles a Request to convert it to a Response. </span><span> 5</span> <span> * </span><span> 6</span> <span> * @param Request $request A Request instance </span><span> 7</span> <span> * </span><span> 8</span> <span> * @return Response A Response instance </span><span> 9</span> <span>*/</span> <span>10</span> <span>function</span> handle(Request <span>$request</span>, <span>$type</span> = self::MASTER_REQUEST, <span>$catch</span> = <span>true</span><span>); </span><span>11</span> }
它接受一个Request输入并返回一个Response输出。 只要遵循这个接口规定,你就能使用Symfony2中所有的精彩内容。
下面使用Symfony2 组件来创建一个简单的框架:
<span> 1</span> <span>$routes</span> = <span>new</span><span> RouteCollection(); </span><span> 2</span> <span>$routes</span>->add('hello', <span>new</span> Route('/hello', <span>array</span>('_controller' => <span> 3</span> <span>function</span> (Request <span>$request</span><span>) { </span><span> 4</span> <span>return</span> <span>new</span> Response(<span>sprintf</span>("Hello %s", <span>$request</span>->get('name'<span>))); </span><span> 5</span> <span> } </span><span> 6</span> <span>))); </span><span> 7</span> <span> 8</span> <span>$request</span> = Request::<span>createFromGlobals(); </span><span> 9</span> <span>10</span> <span>$context</span> = <span>new</span><span> RequestContext(); </span><span>11</span> <span>$context</span>->fromRequest(<span>$request</span><span>); </span><span>12</span> <span>13</span> <span>$matcher</span> = <span>new</span> UrlMatcher(<span>$routes</span>, <span>$context</span><span>); </span><span>14</span> <span>15</span> <span>$dispatcher</span> = <span>new</span><span> EventDispatcher(); </span><span>16</span> <span>$dispatcher</span>->addSubscriber(<span>new</span> RouterListener(<span>$matcher</span><span>)); </span><span>17</span> <span>18</span> <span>$resolver</span> = <span>new</span><span> ControllerResolver(); </span><span>19</span> <span>20</span> <span>$kernel</span> = <span>new</span> HttpKernel(<span>$dispatcher</span>, <span>$resolver</span><span>); </span><span>21</span> <span>22</span> <span>$kernel</span>->handle(<span>$request</span>)->send();
ok, 这就是框架了!
如果想添加一个HTTP反向代理以获取HTTP caching和ESI(Edge Side Includes)带来的好处,那么这样做!
<span>1</span> <span>$kernel</span> = <span>new</span> HttpKernel(<span>$dispatcher</span>, <span>$resolver</span><span>); </span><span>2</span> <span>3</span> <span>$kernel</span> = <span>new</span> HttpCache(<span>$kernel</span>, <span>new</span> Store(__DIR__.'/cache'));
想对它做一下功能测试:
<span>1</span> <span>$client</span> = <span>new</span> Client(<span>$kernel</span><span>); </span><span>2</span> <span>$crawler</span> = <span>$client</span>->request('GET', '/hello/Fabien'<span>); </span><span>3</span> <span>4</span> <span>$this</span>->assertEquals('Fabien', <span>$crawler</span>->filter('p > span')->text());
想要一个好看的错误展示页面?
<span>1</span> <span>$dispatcher</span>->addSubscriber(<span>new</span> ExceptionListener(<span>function</span> (Request <span>$request</span><span>) { </span><span>2</span> <span>$msg</span> = 'Something went wrong! ('.<span>$request</span>->get('exception')->getMessage().')'<span>; </span><span>3</span> <span>4</span> <span>return</span> <span>new</span> Response(<span>$msg</span>, 500<span>); </span><span>5</span> }));
(1).转动一次;旋转一圈。 南朝 梁武帝 《白紵辞》:“短歌流目未肯前,含笑一转私自怜。” 唐 顾况 《悲歌》之二:“我心皎洁君不知,辘轳一转一惆怅。” 元 王实甫 《西厢记》第一本第一折:“怎当他临去秋波那一转!”《儿女英雄传》第四回:“且说那女子把那石头撂倒在平地上,用右手推着一转,找着那个关眼儿伸进两个指头去勾住了。”
(2).提炼一次。 晋 葛洪 《抱朴子·金丹》:“其一转至九转,迟速各有日数,多少以此知之耳。”
(3).计算一遍。 南朝 宋 刘义庆 《世说新语·文学》:“尝算浑天不合,诸弟子莫能解。或言 玄 ( 郑玄 )能者。 融 ( 马融 )令算,一转便决。”
(4).四周。《儒林外史》第十四回:“两边一望,一边是江,一边是湖,又有那山色一转围着。”《儒林外史》第三十回:“诸名士看这湖亭时,轩窗四起,一转都是湖水围绕。”
(1).转换勋阶一次。《新唐书·太宗纪》:“从伐 高丽 无功者,皆赐勋一转。”
(2).表数量。 清 翟灏 《通俗编·数目》引 李翊 《俗呼小录》:“ 杭州 以柴四圆箍为一转。”
ZDIC.NET 汉 典 网
【一转语】 禅宗机锋往来的关键处,称“玄关”。破“玄关”必须亲证实悟。以片言只语,拨转对方的心机,使之冲破“玄关”,“柳暗花明又一村”,谓之“转语”。《景德传灯录·百丈怀海禅师》指出:“古人只错对一转语,五百生堕野狐身。”可见“转语”的重要。举几个例子。问:“不起一念有过无过?”答:“须弥山。”又如问;“磨砖岂成镜耶?”答:“磨砖既不成镜,坐禅岂得成佛耶!”后亦用“一转语”指别出心裁。如宋·张元干《青玉案》词序:“贺方回所作,世间和韵者多矣。余经行松江,何啻百回,念欲下一转语。”也指用一二句话让人恍然大悟。如胡适《尝试篇》:“尝试成功自古无,放翁此语未必是;我今为下一转语,自古成功在尝试。”
这句应该算是老生常谈了,但是对于情绪和心境的控制并不是时时刻刻都能做得那么好。也会偶有愤怒,妒嫉,怨恨产生。从前一直说自己是个不懂掩藏情绪的人,喜怒哀乐全部写在脸上。乍一听好像说的是种直率,但其实不然。直至一日在我因为某事极度悲愤而又试图掩盖时,仍然被一位心细的朋友发现并且直言:你板着脸的时候真的很难看。原来不是要懂得隐藏不好的情绪,如果坏情绪不走,是无法从根本上改变周遭的;我们做的是要懂得如果化解不好的情绪。 现在资源信息发达,有很多途径可以读到好的文字和文章,在此愿以好文与大家分享。 希望我们都能做一个懂得自己,懂得如何让自己快乐和幸福的自己。 --------------------------------------共享的分割线------------------------------------ 【转载】文章来源:天机文献 在古代,形成了一种预测术面相学,是专门以人的五官所储存的信息来推断一个人的祸、福、吉、凶的,面相学,是中国人家喻户晓的,俗话说:人是一面相。一眼就能看出一个人的五观及外貌,同时带给人的第一感观及印象。当你走到大街上或者是去自由市场,走一走,看一看,哪是正人君子,哪是小偷,你一眼就能认出来,因为小偷跟正常人的眼神不一样。 在国民革命时期,中国正处在乱世之秋,龙蛇混杂,草莽逞英雄时代,社会秩序很乱在大上海警察局里,就有一位精通。相法的巡警,凡是他所见到的贼眉鼠眼之人见了就抓每当审问后所抓之人均供认,曾有过偷窃和做坏事的行为,他能抓十个准十个,这就说明:他所掌握的相法是准确的,科学的。 其实,人一生下来,一生中的吉凶祸福,全都包含在人的五官当中人的五官相就是一副人的生命信息图,人的寿命的长短,父母的早亡,子女的多少,兄弟的祸福,婚姻的克离,无不表现在人的五官之中。为什么心地善良的人,他所长的相貌就和善心地凶恶的人,所长出的相貎就狡狯呢?这就反出了一条亘古不变的哲理一相心生。 心是人们常说的内心深处的思维活动,并不单纯指的是人的心脏。内心里想的什么,在五官上就能现表什么。当一个人内心有兴奋的或有使人高兴的事情,这个人就笑口常开,让别人一看便知道在他身上一定有喜悦的事情发生。相反当一个人有悲伤的事情发生,表现在他面上则是哭丧的表情。总之,人的喜、怒、哀、乐、悲、思、恐、惊无不表现在五官相上,五官就是一个很精确的测量仪。 黄帝内经中有表里如一论,外是由内而发,内则靠外来表现。当一个有胃病的人,去看医生,医师则用望、闻、问、切给他诊病,当医生看到病人的鼻准头有红而赤的颜色时,就能判断出此人有胃病,这就是全息理论表现形式。人的思维也是一样,当一个人对另一个人有深仇大恨,并且想杀掉这个人要报仇的时候,他的两眼足以能喷出火来,目露凶光,双目流露杀气,当他想找一位相师占卜一下,问一下行动是否成功的时候,相师就说:你目露杀气,请你不要挺而走险。 我认识一位爱好周易的老太太,约有六十来岁,大家都叫她苗坡。第一次与她相识,是在三角花‘园,她让我给她测一下运气。我看到她相上左边眼下卧蚕,有三条纹,最下面的一条纹,不是平直向左方伸展,而是向左下方穿过左颧,我间:苗姨,你的小女儿在家吗?她回答:哎呀,我就是为这事来预测的,小女儿随一个小伙子私奔了,现在不知道她去了什么地方?事过月余,再遇到苗太太时,间及小女儿的事,已经回家来了,再瞧瞧苗太太的那条卧蚕纹也平直伸展了。这就说明,相是随内心的思维而发生变化的。当她的小女儿走后,她整日里思念、烦恼,这种思维能量就表现在五官上了。相由心生,境随心转这句话出自佛教的揭语,被很多人经常挂在......余下全文>>

핫 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)

뜨거운 주제











ccsvchst.exe는 SEP(Symantec Endpoint Protection) 소프트웨어의 일부인 공통 프로세스 파일이며, SEP는 잘 알려진 네트워크 보안 회사인 Symantec이 개발한 엔드포인트 보호 솔루션입니다. 소프트웨어의 일부로 ccsvchst.exe는 SEP 관련 프로세스를 관리하고 모니터링하는 역할을 담당합니다. 먼저 SymantecEndpointProtection(

HTTP 상태 코드 520은 서버가 요청을 처리하는 동안 알 수 없는 오류가 발생하여 더 구체적인 정보를 제공할 수 없음을 의미합니다. 서버가 요청을 처리하는 동안 알 수 없는 오류가 발생했음을 나타내는 데 사용됩니다. 이는 서버 구성 문제, 네트워크 문제 또는 기타 알 수 없는 이유로 인해 발생할 수 있습니다. 이는 일반적으로 서버 구성 문제, 네트워크 문제, 서버 과부하 또는 코딩 오류로 인해 발생합니다. 상태 코드 520 오류가 발생하면 웹사이트 관리자나 기술 지원팀에 문의하여 자세한 정보와 지원을 받는 것이 가장 좋습니다.

HTTP 상태 코드 403은 서버가 클라이언트의 요청을 거부했음을 의미합니다. http 상태 코드 403에 대한 해결 방법은 다음과 같습니다. 1. 서버에 인증이 필요한 경우 올바른 자격 증명이 제공되었는지 확인합니다. 2. 서버가 IP 주소를 제한한 경우 클라이언트의 IP 주소가 제한되어 있거나 블랙리스트에 없습니다. 3. 파일 권한 설정을 확인하십시오. 403 상태 코드가 파일 또는 디렉토리의 권한 설정과 관련되어 있으면 클라이언트가 해당 파일 또는 디렉토리에 액세스할 수 있는 권한이 있는지 확인하십시오. 등.

HTTP 301 상태 코드의 의미 이해: 웹 페이지 리디렉션의 일반적인 응용 시나리오 인터넷의 급속한 발전으로 인해 사람들은 웹 페이지 상호 작용에 대한 요구 사항이 점점 더 높아지고 있습니다. 웹 디자인 분야에서 웹 페이지 리디렉션은 HTTP 301 상태 코드를 통해 구현되는 일반적이고 중요한 기술입니다. 이 기사에서는 HTTP 301 상태 코드의 의미와 웹 페이지 리디렉션의 일반적인 응용 프로그램 시나리오를 살펴봅니다. HTTP301 상태 코드는 영구 리디렉션(PermanentRedirect)을 나타냅니다. 서버가 클라이언트의 정보를 받을 때

NginxProxyManager를 사용하여 HTTP에서 HTTPS로의 자동 점프를 구현하는 방법 인터넷이 발전하면서 점점 더 많은 웹사이트가 HTTPS 프로토콜을 사용하여 데이터 전송을 암호화하여 데이터 보안과 사용자 개인 정보 보호를 향상시키기 시작했습니다. HTTPS 프로토콜에는 SSL 인증서 지원이 필요하므로 HTTPS 프로토콜 배포 시 특정 기술 지원이 필요합니다. Nginx는 강력하고 일반적으로 사용되는 HTTP 서버 및 역방향 프록시 서버이며 NginxProxy

듀얼 코어 브라우저는 두 개의 서로 다른 브라우저 코어를 통합하는 브라우저 소프트웨어입니다. 커널은 웹 콘텐츠를 렌더링하고 웹 스크립트 및 기타 기능을 실행하는 브라우저의 핵심 부분입니다. 기존 브라우저는 일반적으로 Trident 커널을 사용하는 IE 브라우저, WebKit/Blink 커널을 사용하는 Chrome 브라우저, Gecko 커널을 사용하는 Firefox 브라우저 등 단일 커널만 사용합니다. 듀얼 코어 브라우저는 두 개의 서로 다른 코어를 하나의 브라우저에 통합하고 사용자는 필요에 따라 자유롭게 전환할 수 있습니다. 듀얼 코어 브라우저의 등장

C#의 일반적인 네트워크 통신 및 보안 문제와 해결 방법 오늘날 인터넷 시대에 네트워크 통신은 소프트웨어 개발에 없어서는 안 될 부분이 되었습니다. C#에서는 일반적으로 데이터 전송 보안, 네트워크 연결 안정성 등과 같은 일부 네트워크 통신 문제가 발생합니다. 이 문서에서는 C#의 일반적인 네트워크 통신 및 보안 문제에 대해 자세히 설명하고 해당 솔루션과 코드 예제를 제공합니다. 1. 네트워크 통신 문제 네트워크 연결 중단: 네트워크 통신 과정에서 네트워크 연결이 중단될 수 있으며, 이로 인해

해결 방법: 1. 요청 헤더에서 Content-Type을 확인합니다. 2. 요청 본문에서 데이터 형식을 확인합니다. 3. 적절한 인코딩 형식을 사용합니다. 4. 적절한 요청 방법을 사용합니다. 5. 서버측 지원을 확인합니다.
