<?xml version="1.0" encoding="utf-8"?><feed xmlns="http://www.w3.org/2005/Atom"><title type="text">博客园_Visit Shenzhen, Shenzhen China, Shenzhen Travel Guide</title><subtitle type="text">Shenzhen Universiade - Shenzhen 2011 Summer Universiade</subtitle><id>http://feed.cnblogs.com/blog/u/10001/rss</id><updated>2011-10-18T10:35:15Z</updated><author><name>kaixin110</name><uri>http://www.cnblogs.com/kaixin110/</uri></author><generator>CNBlogs BlogServer</generator><link rel="alternate" type="text/html" href="http://www.cnblogs.com/kaixin110/"/><link rel="self" type="application/atom+xml" href="http://feed.cnblogs.com/blog/u/10001/rss"/><entry><id>http://www.cnblogs.com/kaixin110/archive/2011/06/16/2082483.html</id><title type="text">Difference between BasicHttpBinding and WsHttpBinding</title><summary type="text">Introduction and GoalWCF has introduced lot of bindings and protocols. This article will concentrate on two important protocols BasicHttpBinding and WsHttpBinding which look similar but have some huge fundamental differences. So we will first start with the difference and then we will create a small</summary><published>2011-06-16T03:21:00Z</published><updated>2011-06-16T03:21:00Z</updated><author><name>kaixin110</name><uri>http://www.cnblogs.com/kaixin110/</uri></author><link rel="alternate" href="http://www.cnblogs.com/kaixin110/archive/2011/06/16/2082483.html"/><link rel="alternate" type="text/html" href="http://www.cnblogs.com/kaixin110/archive/2011/06/16/2082483.html"/><content type="html">&lt;p&gt;&lt;strong&gt;&lt;a name="Introduction and Goal"&gt;Introduction and Goal&lt;/a&gt;&lt;/strong&gt;&lt;/p&gt;&#xD;
&lt;p&gt;&lt;span &gt;WCF&lt;/span&gt; has introduced lot of bindings and protocols. This article will concentrate on two important protocols &lt;code&gt;&lt;span &gt;BasicHttpBinding&lt;/span&gt; &lt;/code&gt;and &lt;code&gt;&lt;span &gt;WsHttpBinding&lt;/span&gt; &lt;/code&gt;which&#xD;
 look similar but have some huge fundamental differences. So we will &#xD;
first start with the difference and then we will create a small project &#xD;
and see how the differences look practically.&lt;/p&gt;&#xD;
&lt;p&gt;Now a days, I am distributing my 400 questions and answers ebook which covers major .NET related topics like &lt;span &gt;WCF&lt;/span&gt;, WPF, WWF, Ajax, Core .NET, SQL Server, Architecture and a lot more. I am sure you will enjoy &lt;a href="http://www.questpond.com/SampleDotNetInterviewQuestionBook.zip"&gt;this ebook&lt;/a&gt;.&lt;/p&gt;&#xD;
&lt;p&gt;&lt;strong&gt;&lt;a name="Pre-requisite"&gt;Pre-requisite&lt;/a&gt;&lt;/strong&gt;&lt;/p&gt;&#xD;
&lt;p&gt;In case you are new to &lt;span &gt;WCF&lt;/span&gt;, please do read the basics from the below given links. Basics of &lt;span &gt;WCF&lt;/span&gt; are not in the scope of this article:&lt;/p&gt;&#xD;
&lt;ul&gt;&#xD;
&lt;li&gt;&lt;a href="http://www.codeproject.com/KB/aspnet/WCF.aspx"&gt;Windows Communication Framework (&lt;span &gt;WCF&lt;/span&gt;) - Part 1&lt;/a&gt; &lt;/li&gt;&#xD;
&lt;li&gt;&lt;a href="http://www.codeproject.com/KB/aspnet/WCFPart2.aspx"&gt;Windows Communication Framework (&lt;span &gt;WCF&lt;/span&gt;) - Part 2&lt;/a&gt; &lt;/li&gt;&#xD;
&lt;/ul&gt;&#xD;
&lt;p&gt;&lt;strong&gt;&lt;a name="Difference between BasicHttpBinding and WsHttpBinding"&gt;Difference between &lt;span &gt;BasicHttpBinding&lt;/span&gt; and &lt;span &gt;WsHttpBinding&lt;/span&gt;&lt;/a&gt;&lt;/strong&gt;&lt;/p&gt;&#xD;
&lt;p&gt;If we want to summarize in one sentence, the difference between &lt;code&gt;&lt;span &gt;WsHttpBinding&lt;/span&gt;&lt;/code&gt; and &lt;code&gt;&lt;span &gt;BasicHttpBinding&lt;/span&gt;&lt;/code&gt; is that &lt;code&gt;&lt;span &gt;WsHttpBinding&lt;/span&gt;&lt;/code&gt; supports WS-* specification. WS-* specifications are nothing but standards to extend web service capabilities.&lt;/p&gt;&#xD;
&lt;p&gt;Below is a detailed comparison table between both the entities from &#xD;
security, compatibility, reliability and SOAP version perspective.&lt;/p&gt;&#xD;
&lt;table  width="640"&gt;&#xD;
&lt;thead&gt;&#xD;
&lt;tr&gt;&#xD;
&lt;td&gt;Criteria &lt;/td&gt;&#xD;
&lt;td&gt;&lt;span &gt;BasicHttpBinding&lt;/span&gt; &lt;/td&gt;&#xD;
&lt;td&gt;&lt;span &gt;WsHttpBinding&lt;/span&gt; &lt;/td&gt;&#xD;
&lt;/tr&gt;&#xD;
&lt;/thead&gt;&#xD;
&#xD;
&lt;tbody&gt;&#xD;
&lt;tr&gt;&#xD;
&lt;td&gt;Security support &lt;/td&gt;&#xD;
&lt;td&gt;This supports the old ASMX style, i.e. WS-BasicProfile 1.1. &lt;/td&gt;&#xD;
&lt;td&gt;This exposes web services using WS-* specifications.&lt;/td&gt;&#xD;
&lt;/tr&gt;&#xD;
&lt;tr&gt;&#xD;
&lt;td&gt;Compatibility &lt;/td&gt;&#xD;
&lt;td&gt;This is aimed for clients who do not have .NET 3.0 installed and it &#xD;
supports wider ranges of clients. Many of the clients like Windows 2000 &#xD;
still do not run .NET 3.0. So older version of .NET can consume this &#xD;
service. &lt;/td&gt;&#xD;
&lt;td&gt;As its built using WS-* specifications, it does not support wider &#xD;
ranges of client and it cannot be consumed by older .NET version less &#xD;
than 3 version.&lt;/td&gt;&#xD;
&lt;/tr&gt;&#xD;
&lt;tr&gt;&#xD;
&lt;td&gt;Soap version &lt;/td&gt;&#xD;
&lt;td&gt;SOAP 1.1&lt;/td&gt;&#xD;
&lt;td&gt;SOAP 1.2 and WS-Addressing specification. &lt;/td&gt;&#xD;
&lt;/tr&gt;&#xD;
&lt;tr&gt;&#xD;
&lt;td&gt;Reliable messaging &lt;/td&gt;&#xD;
&lt;td&gt;Not supported. In other words, if a client fires two or three calls &#xD;
you really do not know if they will return back in the same order. &lt;/td&gt;&#xD;
&lt;td&gt;Supported as it supports WS-* specifications. &lt;/td&gt;&#xD;
&lt;/tr&gt;&#xD;
&lt;tr&gt;&#xD;
&lt;td&gt;Default security options &lt;/td&gt;&#xD;
&lt;td&gt;By default, there is no security provided for messages when the &#xD;
client calls happen. In other words, data is sent as plain text. &lt;/td&gt;&#xD;
&lt;td&gt;As &lt;code&gt;WsHttBinding &lt;/code&gt;supports WS-*, it has WS-Security enabled by default. So the data is not sent in plain text. &lt;/td&gt;&#xD;
&lt;/tr&gt;&#xD;
&lt;tr&gt;&#xD;
&lt;td&gt;Security options &lt;/td&gt;&#xD;
&lt;td&gt;&#xD;
&lt;ul&gt;&#xD;
&lt;li&gt;None &lt;/li&gt;&#xD;
&lt;li&gt;Windows &amp;ndash; default authentication &lt;/li&gt;&#xD;
&lt;li&gt;Basic &lt;/li&gt;&#xD;
&lt;li&gt;Certificate &lt;/li&gt;&#xD;
&lt;/ul&gt;&#xD;
&lt;/td&gt;&#xD;
&lt;td&gt;&#xD;
&lt;ul&gt;&#xD;
&lt;li&gt;None &lt;/li&gt;&#xD;
&lt;li&gt;Transport &lt;/li&gt;&#xD;
&lt;li&gt;Message &lt;/li&gt;&#xD;
&lt;li&gt;Transport with message credentials &lt;/li&gt;&#xD;
&lt;/ul&gt;&#xD;
&lt;/td&gt;&#xD;
&lt;/tr&gt;&#xD;
&lt;/tbody&gt;&#xD;
&lt;/table&gt;&#xD;
&lt;p&gt;One of the biggest differences you must have noticed is the security aspect. By default, &lt;code&gt;&lt;span &gt;BasicHttpBinding&lt;/span&gt;&lt;/code&gt; sends data in plain text while &lt;code&gt;&lt;span &gt;WsHttpBinding&lt;/span&gt;&lt;/code&gt; sends it in encrypted and secured manner. To demonstrate the same, lets make two services, one using &lt;code&gt;&lt;span &gt;BasicHttpBinding&lt;/span&gt;&lt;/code&gt; and the other using &lt;code&gt;&lt;span &gt;WsHttpBinding&lt;/span&gt;&lt;/code&gt; and then lets see the security aspect in a more detailed manner.&lt;/p&gt;&#xD;
&lt;p&gt;We will create a small sample to see how &lt;code&gt;&lt;span &gt;BasicHttpBinding&lt;/span&gt;&lt;/code&gt; sends data in plain text format and how &lt;code&gt;&lt;span &gt;WsHttpBinding&lt;/span&gt;&lt;/code&gt; encrypts data.&lt;/p&gt;&#xD;
&lt;p&gt;&lt;em&gt;&lt;strong&gt;Note: By default, security is not enabled on &lt;code&gt;&lt;span &gt;BasicHttpBinding&lt;/span&gt;&lt;/code&gt;&#xD;
 for interoperability purposes. In other words, it is like our old &#xD;
webservice, i.e. ASMX. But that does not mean we cannot enable security &#xD;
in &lt;code&gt;&lt;span &gt;BasicHttpBinding&lt;/span&gt;&lt;/code&gt;. Sometime back, we had a written &lt;/strong&gt;&lt;a href="http://www.codeproject.com/KB/WCF/WCFBasicHttpBinding.aspx"&gt;&lt;strong&gt;an article&lt;/strong&gt;&lt;/a&gt;&lt;strong&gt; on how to enable security on &lt;code&gt;&lt;span &gt;BasicHttpBinding&lt;/span&gt;&lt;/code&gt;.&lt;/strong&gt; &lt;/em&gt;&lt;/p&gt;&lt;img src="http://www.cnblogs.com/kaixin110/aggbug/2082483.html?type=1" width="1" height="1" alt=""/&gt;&lt;p&gt;&lt;a href="http://www.cnblogs.com/kaixin110/archive/2011/06/16/2082483.html" target="_blank"&gt;本文链接&lt;/a&gt;&lt;/p&gt;</content></entry><entry><id>http://www.cnblogs.com/kaixin110/archive/2011/06/16/2082397.html</id><title type="text">Using WCF Services with PHP</title><summary type="text">I recently wrote two postings on the subject of WCF services: WCF Services – Let&amp;#39;s Get Started and WCF and Unit Tests. One could see that creating and testing services was not complicated at all. Let&amp;#39;s go on and take some steps nearer to the real world – our service is used by SOAP clients r</summary><published>2011-06-16T02:12:00Z</published><updated>2011-06-16T02:12:00Z</updated><author><name>kaixin110</name><uri>http://www.cnblogs.com/kaixin110/</uri></author><link rel="alternate" href="http://www.cnblogs.com/kaixin110/archive/2011/06/16/2082397.html"/><link rel="alternate" type="text/html" href="http://www.cnblogs.com/kaixin110/archive/2011/06/16/2082397.html"/><content type="html">&lt;p&gt;I recently wrote two postings on the subject of WCF &#xD;
services: WCF Services &amp;ndash; Let's Get Started and WCF and Unit Tests. One &#xD;
could see that creating and testing services was not complicated at all.&#xD;
 Let's go on and take some steps nearer to the real world &amp;ndash; our service &#xD;
is used by SOAP clients running on different platforms.&lt;/p&gt;&#xD;
&lt;p&gt;I conducted my first experiment with PHP. PHP is &#xD;
widely used in the world of the Web and in all likelihood there will &#xD;
dawn a day when DT is asked just for such an integration. As PHP4 &#xD;
development and support is soon going to be discontinued, I didn't &#xD;
bother with an example using PHP4 SOAP tools. PHP5 is on the market and &#xD;
it comes with a quick and stable SOAP library. The performance is many &#xD;
times better than in case of similar widgets written for PHP4.&lt;/p&gt;&#xD;
&lt;p&gt;I have Apache and PHP5 running on Windows and for &#xD;
SOAP support I have to use an extension named php_soap.dll. Thus, I have&#xD;
 to remove the comment mark in front of the appropriate php.ini line and&#xD;
 restart Apache.&lt;/p&gt;&#xD;
&lt;p align="center"&gt;&lt;img src="http://weblogs.asp.net/blogs/gunnarpeipman/2007/09/math-service.png" border="0" /&gt;&lt;/p&gt;&#xD;
&lt;p&gt;As an example I will present a PHP code calling the &#xD;
service's Add() method and writing the result on the screen. An example &#xD;
of WCF code can be found in our blog, in the posting &lt;strong&gt;&lt;a title="WCF Services &amp;ndash; Let's Get Started" href="http://weblogs.asp.net/gunnarpeipman/archive/2007/09/12/wcf-lets-get-started.aspx"&gt;WCF Services &amp;ndash; Let's Get Started&lt;/a&gt;&lt;/strong&gt;.&lt;/p&gt;&#xD;
&lt;hr size="1" /&gt;&#xD;
&lt;pre&gt;&lt;span style="font-weight: bold; color: #000000;"&gt;&amp;lt;?php&lt;/span&gt;&lt;br /&gt;&lt;a href="http://www.php.net/header"&gt;&lt;span style="color: #000066;"&gt;header&lt;/span&gt;&lt;/a&gt;&lt;span style="font-weight: bold; color: #006600;"&gt;(&lt;/span&gt;&lt;span style="color: #ff0000;"&gt;'Content-Type: text/plain'&lt;/span&gt;&lt;span style="font-weight: bold; color: #006600;"&gt;)&lt;/span&gt;;&#xD;
&#xD;
&lt;a href="http://www.php.net/echo"&gt;&lt;span style="color: #000066;"&gt;echo&lt;/span&gt;&lt;/a&gt; &lt;span style="color: #ff0000;"&gt;"WCF Test&lt;span style="font-weight: bold; color: #000099;"&gt;\r&lt;/span&gt;&lt;span style="font-weight: bold; color: #000099;"&gt;\n&lt;/span&gt;&lt;span style="font-weight: bold; color: #000099;"&gt;\r&lt;/span&gt;&lt;span style="font-weight: bold; color: #000099;"&gt;\n&lt;/span&gt;"&lt;/span&gt;;&#xD;
&#xD;
&lt;span style="color: #0000ff;"&gt;$client&lt;/span&gt; = &lt;span style="font-weight: bold; color: #000000;"&gt;new&lt;/span&gt; SoapClient&lt;span style="font-weight: bold; color: #006600;"&gt;(&lt;/span&gt;&lt;span style="color: #ff0000;"&gt;'http://gamma/wcftest/MathService.svc?wsdl'&lt;/span&gt;&lt;span style="font-weight: bold; color: #006600;"&gt;)&lt;/span&gt;;&lt;br /&gt;&lt;span style="color: #0000ff;"&gt;$obj&lt;/span&gt;-&amp;gt;&lt;span style="color: #006600;"&gt;x&lt;/span&gt; = &lt;span style="color: #cc66cc;"&gt;2&lt;/span&gt;.&lt;span style="color: #cc66cc;"&gt;5&lt;/span&gt;;&lt;br /&gt;&lt;span style="color: #0000ff;"&gt;$obj&lt;/span&gt;-&amp;gt;&lt;span style="color: #006600;"&gt;y&lt;/span&gt; = &lt;span style="color: #cc66cc;"&gt;3&lt;/span&gt;.&lt;span style="color: #cc66cc;"&gt;5&lt;/span&gt;;&lt;br /&gt;&lt;span style="color: #0000ff;"&gt;$retval&lt;/span&gt; = &lt;span style="color: #0000ff;"&gt;$client&lt;/span&gt;-&amp;gt;&lt;span style="color: #006600;"&gt;Add&lt;/span&gt;&lt;span style="font-weight: bold; color: #006600;"&gt;(&lt;/span&gt;&lt;span style="color: #0000ff;"&gt;$obj&lt;/span&gt;&lt;span style="font-weight: bold; color: #006600;"&gt;)&lt;/span&gt;;&#xD;
&#xD;
&lt;a href="http://www.php.net/echo"&gt;&lt;span style="color: #000066;"&gt;echo&lt;/span&gt;&lt;/a&gt; &lt;span style="color: #ff0000;"&gt;"2.5 + 3.5 = "&lt;/span&gt; . &lt;span style="color: #0000ff;"&gt;$retval&lt;/span&gt;-&amp;gt;&lt;span style="color: #006600;"&gt;AddResult&lt;/span&gt;;&lt;br /&gt;&lt;span style="font-weight: bold; color: #000000;"&gt;?&amp;gt;&lt;/span&gt;&lt;/pre&gt;&#xD;
&lt;hr size="1" /&gt;&#xD;
&lt;p&gt;If nothing went wrong, the result should be something like this:&lt;/p&gt;&#xD;
&lt;code&gt;&lt;/code&gt;&#xD;
&lt;pre&gt;WCF Test&#xD;
&amp;nbsp;&amp;nbsp;&amp;nbsp; 2.5 + 3.5 = 6&lt;/pre&gt;&#xD;
&lt;p&gt;As you can see, using WCF services in PHP is very &#xD;
simple. The SOAP library provided along with PHP5 does a great deal of &#xD;
the work "behind the curtains", leaving us with an easily readable brief&#xD;
 code.&lt;/p&gt;&lt;img src="http://www.cnblogs.com/kaixin110/aggbug/2082397.html?type=1" width="1" height="1" alt=""/&gt;&lt;p&gt;&lt;a href="http://www.cnblogs.com/kaixin110/archive/2011/06/16/2082397.html" target="_blank"&gt;本文链接&lt;/a&gt;&lt;/p&gt;</content></entry><entry><id>http://www.cnblogs.com/kaixin110/archive/2011/06/16/2082395.html</id><title type="text">PHP calling .NET – Running WCF service with basicHttpBinding</title><summary type="text">am Writing a PHP application that needs to run a back end .NET application. When creating a running the WCF web service out of the box, the PHP could not connect to the web service.The problem:The PHP returns &amp;quot;Caught exception: Cannot process the message because the content type ‘text/xml; char</summary><published>2011-06-16T02:11:00Z</published><updated>2011-06-16T02:11:00Z</updated><author><name>kaixin110</name><uri>http://www.cnblogs.com/kaixin110/</uri></author><link rel="alternate" href="http://www.cnblogs.com/kaixin110/archive/2011/06/16/2082395.html"/><link rel="alternate" type="text/html" href="http://www.cnblogs.com/kaixin110/archive/2011/06/16/2082395.html"/><content type="html">am Writing a PHP application that needs to run a back end .NET &#xD;
application. When creating a running the WCF web service out of the box,&#xD;
 the PHP could not connect to the web service.&#xD;
&lt;p&gt;&lt;strong&gt;&lt;span style="text-decoration: underline;"&gt;The problem:&lt;/span&gt;&lt;/strong&gt;&lt;/p&gt;&#xD;
&lt;p&gt;The PHP returns "&lt;em&gt;Caught exception: Cannot process the message &#xD;
because the content type &amp;lsquo;text/xml; charset=utf-8&amp;prime; was not the expected &#xD;
type &amp;lsquo;application/soap+xml; charset=utf-8&amp;prime;&lt;/em&gt;."&lt;/p&gt;&#xD;
&#xD;
&lt;p&gt;&lt;strong&gt;&lt;span style="text-decoration: underline;"&gt;The reason:&lt;/span&gt;&lt;/strong&gt;&lt;/p&gt;&#xD;
&lt;p&gt;WCF is running a new version of web services than expected by the PHP.&lt;/p&gt;&#xD;
&#xD;
&lt;p&gt;&lt;strong&gt;&lt;span style="text-decoration: underline;"&gt;The solution:&lt;/span&gt;&lt;/strong&gt;&lt;/p&gt;&#xD;
&lt;p&gt;Change the binding type of the WCF service from &lt;strong&gt;binding="wsHttpBinding"&lt;/strong&gt; to &lt;strong&gt;binding="basicHttpBinding"&lt;/strong&gt;.&lt;/p&gt;&#xD;
&lt;p&gt;This insures that your .NET web service would support clients and other services that conform to the WS-I standards.&lt;/p&gt;&lt;img src="http://www.cnblogs.com/kaixin110/aggbug/2082395.html?type=1" width="1" height="1" alt=""/&gt;&lt;p&gt;&lt;a href="http://www.cnblogs.com/kaixin110/archive/2011/06/16/2082395.html" target="_blank"&gt;本文链接&lt;/a&gt;&lt;/p&gt;</content></entry><entry><id>http://www.cnblogs.com/kaixin110/archive/2010/12/14/1905164.html</id><title type="text">Resolving a Fatal error: Call to undefined function mysql_connect() in RedHat</title><summary type="text">SymptomsIn RedHat Linux, you have installed the PHP, MySQL, and Apache packages through the package manager.  After starting the MySQL and Apache services through the service manager, you write a simple test php page to access the MySQL database.  When the page is loaded in the web browser, you rece</summary><published>2010-12-13T16:58:00Z</published><updated>2010-12-13T16:58:00Z</updated><author><name>kaixin110</name><uri>http://www.cnblogs.com/kaixin110/</uri></author><link rel="alternate" href="http://www.cnblogs.com/kaixin110/archive/2010/12/14/1905164.html"/><link rel="alternate" type="text/html" href="http://www.cnblogs.com/kaixin110/archive/2010/12/14/1905164.html"/><content type="html">&lt;p&gt;&lt;strong&gt;Symptoms&lt;/strong&gt;&lt;/p&gt;&#xD;
&lt;p&gt;In RedHat Linux, you have installed the PHP, MySQL, and Apache packages through the package manager.  After starting the MySQL and Apache services through the service manager, you write a simple test php page to access the MySQL database.  When the page is loaded in the web browser, you receive the error, &lt;em&gt;Fatal error: Call to undefined function mysql_connect()&lt;/em&gt;.&lt;/p&gt;&#xD;
&lt;p&gt;&lt;strong&gt;Sample Code&lt;/strong&gt;&lt;/p&gt;&#xD;
&lt;pre&gt;&amp;lt;?php&lt;br /&gt;$link = mysql_connect('localhost', 'mysql_user', 'mysql_password');&lt;br /&gt;if (!$link) {&lt;br /&gt;   die('Could not connect: ' . mysql_error());&lt;br /&gt;}&lt;br /&gt;echo 'Connected successfully';&lt;br /&gt;mysql_close($link);&lt;br /&gt;?&amp;gt;&lt;/pre&gt;&#xD;
&lt;p&gt;&lt;strong&gt;Cause&lt;/strong&gt;&lt;/p&gt;&#xD;
&lt;p&gt;The mysql.so extension library does not come with the PHP or MySQL distributions.  It must be installed separately by downloading the php-mysql RPM.&#xD;
&lt;/p&gt;&#xD;
&lt;p&gt;&lt;strong&gt;Fix&lt;/strong&gt;&lt;/p&gt;&#xD;
&lt;ol&gt;&#xD;
&lt;li&gt;Verify that your installation of PHP has been compiled with mysql support.  Create a test web page containing &lt;code&gt;&amp;lt;?php&amp;nbsp;phpinfo();&amp;nbsp;exit();&amp;nbsp;?&amp;gt;&lt;/code&gt; and load it in your browser.  Search the page for &lt;em&gt;MySQL&lt;/em&gt;.  If you don't see it, you need to recompile PHP with MySQL support, or reinstall a PHP package that has it built-in, both of which are beyond the scope of this document.&lt;/li&gt;&#xD;
&lt;li&gt;Verify that the line to load the extension in &lt;code&gt;php.ini&lt;/code&gt; has been uncommented.  In Linux, the line is &lt;code&gt;extension=mysql.so&lt;/code&gt; and in Windows, the line is &lt;code&gt;extension=php_mysql.dll&lt;/code&gt;.  Uncomment the line by removing the semi-colon. You might also need to configure the &lt;code&gt;extension_dir&lt;/code&gt; variable.&lt;/li&gt;&#xD;
&lt;li&gt;Check if the php-mysql package is installed by opening a terminal window (bash), and typing, &lt;code&gt;rpm&amp;nbsp;-qa&amp;nbsp;|&amp;nbsp;grep&amp;nbsp;php&lt;/code&gt;.  If you don't see it, make a note of the exact version of PHP that is installed.&lt;/li&gt;&#xD;
&lt;li&gt;Find the php-mysql RPM for the version of PHP that is installed on your system.  The easiest way to find it is to search by the version of RedHat you have.  Go to a &lt;a href="http://mirrors.fedoraproject.org/publiclist"&gt;RedHat mirror&lt;/a&gt; or look on your RedHat CDs.  If you have RedHat 8.0, then navigate to the folder &lt;code&gt;/linux/8.0/en/os/i386/RedHat/RPMS/&lt;/code&gt; and search for php-mysql.  Download this file. (For a list of mirror sites, try &lt;a href="http://mirrors.fedoraproject.org/publiclist"&gt;RedHat Mirrors&lt;/a&gt; or search Google for &lt;em&gt;redhat mirrors&lt;/em&gt;.)&lt;/li&gt;&#xD;
&lt;li&gt;To install the file, open a terminal window and &lt;code&gt;cd&lt;/code&gt; to the directory where you saved the RPM.  Then type &lt;code&gt;rpm&amp;nbsp;-hivv&amp;nbsp;php-mysql-4.2.2-17.i386.rpm&lt;/code&gt; and press enter.  This will install the RPM for RedHat 9.0.&lt;/li&gt;&#xD;
&lt;li&gt;You might also need MySQL-shared-compat RPM if you get a &lt;em&gt;dependency of libmysqlclient.so.10&lt;/em&gt; error while installing.&lt;/li&gt;&#xD;
&lt;li&gt;The last step is to restart Apache.  You can do this with one of the following commands, &lt;code&gt;apachectl&amp;nbsp;restart&lt;/code&gt; or &lt;code&gt;/etc/rc.d/init.d/httpd&amp;nbsp;restart&lt;/code&gt;.&lt;/li&gt;&#xD;
&lt;/ol&gt;&#xD;
&lt;p&gt;&lt;strong&gt;Applies To&lt;/strong&gt;&lt;/p&gt;&#xD;
&lt;p&gt;RedHat 7.x, 8.0, 9.0, Fedora, Apache, MySQL&lt;/p&gt;&lt;img src="http://www.cnblogs.com/kaixin110/aggbug/1905164.html?type=1" width="1" height="1" alt=""/&gt;&lt;p&gt;&lt;a href="http://www.cnblogs.com/kaixin110/archive/2010/12/14/1905164.html" target="_blank"&gt;本文链接&lt;/a&gt;&lt;/p&gt;</content></entry><entry><id>http://www.cnblogs.com/kaixin110/archive/2010/11/12/1875779.html</id><title type="text">提问的艺术</title><summary type="text">。我当初花了2个小时阅读了用户手册后就直接开始开发了，基本上也没遇到过什么大问题。就目 前论坛和QQ群里的一些新手开发者们而言，好多人都是不仔细看用户手册，就问这问那，提问没有错，但是提问有提问的艺术。在国外的技术论坛上经常会看见人 说&amp;ldquo;RTFM&amp;rdquo;，意思就是&amp;ldquo;Read The Fxxxing Manual&amp;rdquo;&amp;mdash;&amp;mdash;看手册！</summary><published>2010-11-12T08:06:00Z</published><updated>2010-11-12T08:06:00Z</updated><author><name>kaixin110</name><uri>http://www.cnblogs.com/kaixin110/</uri></author><link rel="alternate" href="http://www.cnblogs.com/kaixin110/archive/2010/11/12/1875779.html"/><link rel="alternate" type="text/html" href="http://www.cnblogs.com/kaixin110/archive/2010/11/12/1875779.html"/><content type="html">&lt;p&gt;。我当初花了2个小时阅读了用户手册后就直接开始开发了，基本上也没遇到过什么大问题。就目 前论坛和QQ群里的一些新手开发者们而言，好多人都是不仔细看用户手册，就问这问那，提问没有错，但是提问有提问的艺术。在国外的技术论坛上经常会看见人 说&amp;ldquo;RTFM&amp;rdquo;，意思就是&amp;ldquo;Read The Fxxxing Manual&amp;rdquo;&amp;mdash;&amp;mdash;看手册！&lt;/p&gt;&lt;img src="http://www.cnblogs.com/kaixin110/aggbug/1875779.html?type=1" width="1" height="1" alt=""/&gt;&lt;p&gt;&lt;a href="http://www.cnblogs.com/kaixin110/archive/2010/11/12/1875779.html" target="_blank"&gt;本文链接&lt;/a&gt;&lt;/p&gt;</content></entry><entry><id>http://www.cnblogs.com/kaixin110/archive/2010/11/05/1870113.html</id><title type="text">Ubuntu操作系统安装使用教程</title><summary type="text">随着微软的步步紧逼，包括早先的Windows黑屏计划、实施，逮捕番茄花园作者并判刑，种种迹象表明，中国用户免费使用盗版Windows的日子将不会太长久了，那么这个世界上有没有即免费又易用的操作系统呢？答案是有，那就是Ubuntu操作系统。　　Ubuntu是一个流行的Linux操作系统，基于Debian发行版和GNOME桌面环境，和其他Linux发行版相比，Ubuntu非常易用，和Windows相容...</summary><published>2010-11-05T09:08:00Z</published><updated>2010-11-05T09:08:00Z</updated><author><name>kaixin110</name><uri>http://www.cnblogs.com/kaixin110/</uri></author><link rel="alternate" href="http://www.cnblogs.com/kaixin110/archive/2010/11/05/1870113.html"/><link rel="alternate" type="text/html" href="http://www.cnblogs.com/kaixin110/archive/2010/11/05/1870113.html"/><content type="html">&lt;p&gt;随着微软的步步紧逼，包括早先的&lt;a href="http://www.williamlong.info/archives/1532.html" target="_blank"&gt;Windows黑屏计划&lt;/a&gt;、&lt;a href="http://www.williamlong.info/archives/1538.html" target="_blank"&gt;实施&lt;/a&gt;，&lt;a href="http://www.williamlong.info/archives/1468.html" target="_blank"&gt;逮捕番茄花园作者&lt;/a&gt;并&lt;a href="http://www.williamlong.info/archives/1904.html" target="_blank"&gt;判刑&lt;/a&gt;，种种迹象表明，中国用户免费使用盗版Windows的日子将不会太长久了，那么这个世界上有没有即免费又易用的操作系统呢？答案是有，那就是Ubuntu操作系统。&#xD;
&lt;/p&gt;&#xD;
&lt;p&gt;Ubuntu是一个流行的Linux操作系统，基于Debian发行版和GNOME桌面环境，和其他Linux发行版相比，Ubuntu非常易用，和Windows相容性很好，非常适合Windows用户的迁移，预装了大量常用软件，中文版的功能也较全，支持拼音输入法，预装了Firefox、Open Office、多媒体播放、图像处理等大多数常用软件，一般会自动安装网卡、音效卡等设备的驱动，对于不打游戏不用网银的用户来说，基本上能用的功能都有了，在Windows操作系统下不用分区即可安装使用，就如同安装一个应用软件那么容易，整个Ubuntu操作系统在Windows下就如同一个大文件一样，很容易卸载掉。下面我就介绍一下Ubuntu操作系统安装使用的方法，供Ubuntu新手参考，希望能起到Linux扫盲的作用。&lt;/p&gt;&#xD;
&lt;p&gt;&lt;strong&gt;下载Ubuntu&lt;/strong&gt;&lt;/p&gt;&#xD;
&lt;p&gt;Ubuntu有三个版本，分别是桌面版（Desktop Edition），服务器版（Server Edition），上网本版（Netbook Remix），普通桌面电脑使用桌面版即可，下载地址&lt;a href="http://www.ubuntu.com/getubuntu/download" target="_blank"&gt;请点这里&lt;/a&gt;，32位CPU请选择32bit version，上网本则可下载Netbook Remix，目前Ubuntu已经占据三分之一的上网本市场，仅次于WIndows XP系统。Google的Chrome操作系统强有力的对手就是Ubuntu Netbook Remix。&lt;/p&gt;&#xD;
&lt;p&gt;目前最新的版本是9.04版，下载后的文件名是ubuntu-9.04-desktop-i386.iso，大小是698M，通过迅雷下载非常快，大约半个小时左右可以下载完毕。&lt;/p&gt;&#xD;
&lt;p&gt;&lt;strong&gt;安装Ubuntu&lt;/strong&gt;&lt;/p&gt;&#xD;
&lt;p&gt;在Windows下可以不用重新分区，直接像安装一个应用程序那样安装Ubuntu，安装方法是，先使用一个虚拟光驱（&lt;a href="http://www.williamlong.info/archives/991.html" target="_blank"&gt;例如微软的Windows虚拟光驱&lt;/a&gt;）装载ubuntu-9.04-desktop-i386.iso文件，然后运行根目录下的wubi.exe，运行前要&lt;strong&gt;将本地磁盘的名字都修改为英文名&lt;/strong&gt;，否则会出现错误信息&amp;ldquo;UnicodeEncodeError: 'ascii' codec can't encode characters in position 0-3: ordinal not in range(128)&amp;rdquo;而无法运行。&lt;/p&gt;&#xD;
&lt;p&gt;运行之后，会出现如下界面，选择&amp;ldquo;Install inside Windows&amp;rdquo;即可在Windows下直接安装而无需分区。&lt;/p&gt;&#xD;
&lt;p style="text-align: center;"&gt;&lt;img src="http://www.williamlong.info/upload/1905_1.jpg" alt="Ubuntu Wubi" /&gt;&lt;/p&gt;&#xD;
&lt;p&gt;接着出现下面的安装界面，选择一个磁盘，然后将语言选择为&amp;ldquo;Chinese（Simplified）简体中文&amp;rdquo;，Installation size为Ubuntu环境的总共磁盘大小，然后是登录用户名和密码，设置好了以后就点安装继续。&lt;/p&gt;&#xD;
&lt;p style="text-align: center;"&gt;&lt;img src="http://www.williamlong.info/upload/1905_2.jpg" alt="Ubuntu Wubi" /&gt;&lt;/p&gt;&#xD;
&lt;p&gt;后面的安装操作很简单，不需要手动干预就可以直接安装好整个操作系统，大部分的硬件驱动都可以自动安装好。提示安装完毕后，重启系统，就可以使用Ubuntu了。&lt;/p&gt;&#xD;
&lt;p&gt;&lt;strong&gt;自动登录Ubuntu&lt;/strong&gt;&lt;/p&gt;&#xD;
&lt;p&gt;Ubuntu默认是每次登录都是要输入用户名和密码的，这是基于安全方面的考虑，不过对于桌面版，大家都习惯自己的电脑能自动登录，类似Windows XP系统那样，通过一些设置可以实现Ubuntu自动登录。设置的方法是：点击&amp;ldquo;系统&amp;rdquo;&amp;mdash;&amp;ldquo;系统管理&amp;rdquo;&amp;mdash;&amp;ldquo;登录窗口&amp;rdquo; （需要输入管理员密码），然后在&amp;ldquo;安全&amp;rdquo;选项页&amp;mdash;勾选（启用自动登录），然后在下拉列表里选择自己的用户名。之后Ubuntu就能够自动登录了。&lt;/p&gt;&#xD;
&lt;p&gt;&lt;strong&gt;开机自动运行程序&lt;/strong&gt;&lt;/p&gt;&#xD;
&lt;p&gt;类似Windows的启动菜单，在Linux也可以实现开机自动运行一些命令，比较简单的方法是修改 /etc/rc.local 文件，将需要执行的命令添加进去。&lt;/p&gt;&#xD;
&lt;p&gt;&lt;strong&gt;桌面设置&lt;/strong&gt;&lt;/p&gt;&#xD;
&lt;p&gt;Ubuntu的桌面，默认有两个任务栏，一个在上面，一个在下面，通常习惯Windows的用户喜欢将上面的移到下面，Ubuntu的面板无法拖动，在上面点右键后，可以让其显示在屏幕下端。&lt;/p&gt;&#xD;
&lt;p&gt;桌面背景设置和Windows很类似，在&amp;ldquo;桌面&amp;rdquo;上点右键，点更改桌面背景，就可以进行修改设置。&lt;/p&gt;&#xD;
&lt;p&gt;&lt;strong&gt;修改root密码&lt;/strong&gt;&lt;/p&gt;&#xD;
&lt;p&gt;Ubuntu默认的用户并不是root，我们可以通过操作来使用root这个超级管理员帐号，以获得更大的权限。先打开终端，然后执行下面的语句&lt;/p&gt;&#xD;
&lt;p&gt;sudo passwd root&lt;/p&gt;&#xD;
&lt;p&gt;就可以修改超级管理员root的密码，之后就可以使用su命令切换到root用户来执行某些更高权限的操作。&lt;/p&gt;&#xD;
&lt;p&gt;&lt;strong&gt;Hosts修改&lt;/strong&gt;&lt;/p&gt;&#xD;
&lt;p&gt;在Windows下，我们上Twitter等网站都需要修改hosts文件，在Linux下也有hosts文件，文件位于/etc/hosts，使用root用户可以编辑修改这个文件，主机名和IP的格式与Windows的完全相同，例如：&lt;/p&gt;&#xD;
&lt;p&gt;127.0.0.1 localhost&lt;/p&gt;&#xD;
&lt;p&gt;&lt;strong&gt;在Ubuntu下安装软件&lt;/strong&gt;&lt;/p&gt;&#xD;
&lt;p&gt;Ubuntu下的软件安装有几种方式，常用的是deb包的安装方式，deb是debian系列的Linux包管理方式，ubuntu属于debian的派生，也默认支持这种软件安装方式，当下载到一个deb格式的软件后，直接在界面上就可以安装。&lt;/p&gt;&#xD;
&lt;p&gt;另一种常见的安装方式是源代码编译安装，很多软件会提供了源代码给最终用户，用户需要自行编译安装，先使用tar将源代码解压缩到一个目录下，然后进入这个目录，执行以下三条命令：&lt;/p&gt;&#xD;
&lt;p&gt;./configure&lt;/p&gt;&#xD;
&lt;p&gt;make&lt;/p&gt;&#xD;
&lt;p&gt;sudo make install&lt;/p&gt;&#xD;
&lt;p&gt;执行完成后，即可完成软件的编译和安装。&lt;/p&gt;&#xD;
&lt;p&gt;还有一种方式是apt-get的安装方法，APT是Debian及其衍生发行版的软件包管理器，APT可以自动下载，配置，安装二进制或者源代码格式的软件包，因此简化了Unix系统上管理软件的过程。常用的安装命令是：&lt;/p&gt;&#xD;
&lt;p&gt;sudo apt-get install 软件名&lt;/p&gt;&#xD;
&lt;p&gt;sudo apt-get remove 软件名&lt;/p&gt;&#xD;
&lt;p&gt;&lt;strong&gt;Firefox浏览器的更新&lt;/strong&gt;&lt;/p&gt;&#xD;
&lt;p&gt;Ubuntu安装完成后会自动安装一个Firefox浏览器，遗憾的是这个Firefox版本通常较低，例如Ubuntu 9.04会安装Firefox 3.0，不过我们可以想办法下载最新的Firefox覆盖掉老版本Firefox，具体方法是，先上Firefox官方网站下载最新的Linux版本Firefox，然后将其解压缩到某一个目录下，例如firefox目录，进入终端，到这个目录的父目录，执行下面的语句：&lt;/p&gt;&#xD;
&lt;p&gt;sudo cp -r firefox /usr/lib/firefox-3.5.2&lt;/p&gt;&#xD;
&lt;p&gt;sudo mv /usr/bin/firefox /usr/bin/firefox.old&lt;/p&gt;&#xD;
&lt;p&gt;sudo ln -s /usr/lib/firefox-3.5.2/firefox /usr/bin/firefox-3.5.2&lt;/p&gt;&#xD;
&lt;p&gt;sudo ln -s /usr/bin/firefox-3.5.2 /usr/bin/firefox&lt;/p&gt;&#xD;
&lt;p&gt;之后就可以将Firefox成功替换为最新的Firefox 3.52版本，未来的Firefox更新也可以使用这种方法。&lt;/p&gt;&#xD;
&lt;p&gt;&lt;strong&gt;Firefox的Flash问题&lt;/strong&gt;&lt;/p&gt;&#xD;
&lt;p&gt;经过我的实际测试，Ubuntu自动安装的Flash插件swfdec存在很多问题，在Firefox中，很多网页的Flash无法显示，包括Google音乐和开心网等，因此建议使用下面两条语句将其卸载。&lt;/p&gt;&#xD;
&lt;p&gt;sudo apt-get remove swfdec-mozilla&lt;/p&gt;&#xD;
&lt;p&gt;sudo apt-get remove swfdec-gnome&lt;/p&gt;&#xD;
&lt;p&gt;之后可安装官方的Adobe Flash Player的Linux版，下载地址是： &lt;a href="http://get.adobe.com/flashplayer/" target="_blank"&gt;http://get.adobe.com/flashplayer/&lt;/a&gt;&lt;/p&gt;&#xD;
&lt;p&gt;安装完成后，还要解决中文乱码问题，解决方法是执行下面语句：&lt;/p&gt;&#xD;
&lt;p&gt;sudo cp /etc/fonts/conf.d/49-sansserif.conf /etc/fonts/conf.d/49-sansserif.conf.bak&lt;/p&gt;&#xD;
&lt;p&gt;sudo rm /etc/fonts/conf.d/49-sansserif.conf&lt;/p&gt;&#xD;
&lt;p&gt;之后，Firefox的Flash就完全正常了，在Firefox中访问开心网等Flash网站，显示都正常。&lt;/p&gt;&#xD;
&lt;p&gt;&lt;strong&gt;安装常用软件&lt;/strong&gt;&lt;/p&gt;&#xD;
&lt;p&gt;介绍完了安装的方法和Firefox，下面就可以去各个网站下载一些常用的Linux软件来安装了，下面是我整理的一些常用的Linux软件列表：&lt;/p&gt;&#xD;
&lt;p&gt;Linux QQ：访问&lt;a href="http://im.qq.com/qq/linux/" target="_blank"&gt;这个地址&lt;/a&gt;，下载deb文件安装，可以在Linux下玩腾讯QQ。&lt;/p&gt;&#xD;
&lt;p&gt;防火墙 firestarter： 使用 sudo apt-get install firestarter 安装。&lt;/p&gt;&#xD;
&lt;p&gt;杀毒软件 AntiVir: 虽然Linux下的病毒很少，但对于新手还是有必要安装一个杀毒软件，访问&lt;a href="http://www.free-av.com/" target="_blank"&gt;这个地址&lt;/a&gt;可以下载免费版的AntiVir杀毒软件，这个软件我曾经在《&lt;a href="http://www.williamlong.info/archives/1373.html" target="_blank"&gt;五个最佳的防病毒软件&lt;/a&gt;》中介绍过。&lt;/p&gt;&#xD;
&lt;p&gt;rpm 转 deb 工具： 使用 sudo apt-get install alien 安装&lt;/p&gt;&#xD;
&lt;p&gt;JAVA环境安装： JRE的安装 sudo apt-get install sun-java6-jre ，JDK的安装 sudo apt-get install sun-java6-jdk&lt;/p&gt;&#xD;
&lt;p&gt;eclipse安装： 先到&lt;a href="http://www.eclipse.org/downloads/" target="_blank"&gt;这个地址&lt;/a&gt;下载最新的eclipse，然后使用tar xvfz eclipse-php-galileo-linux-gtk.tar.gz -C /opt 解压缩后就可以使用。&lt;/p&gt;&#xD;
&lt;p style="text-align: center;"&gt;&lt;img src="http://www.williamlong.info/upload/1905_3.jpg" alt="eclipse安装" /&gt;&lt;/p&gt;&#xD;
&lt;p&gt;Picasa 3 for Linux安装： 访问&lt;a href="http://picasa.google.com/linux/" target="_blank"&gt;这个地址&lt;/a&gt;，下载后直接安装。&lt;/p&gt;&#xD;
&lt;p&gt;Google Earth安装： 在&lt;a href="http://earth.google.com/download-earth.html" target="_blank"&gt;这里&lt;/a&gt;下载最新版本的Google Earth，下载下来是个BIN文件，在图形界面上右击 GoogleEarthLinux.bin，在&amp;ldquo;权限&amp;rdquo;选项卡中勾选&amp;ldquo;允许以程序执行文件&amp;rdquo;，如下图。&lt;/p&gt;&#xD;
&lt;p style="text-align: center;"&gt;&lt;img src="http://www.williamlong.info/upload/1905_4.jpg" alt="Google Earth安装" /&gt;&lt;/p&gt;&#xD;
&lt;p&gt;之后在终端上执行 ./GoogleEarthLinux.bin 即可安装。&lt;/p&gt;&#xD;
&lt;p style="text-align: center;"&gt;&lt;img src="http://www.williamlong.info/upload/1905_5.jpg" alt="Google Earth安装" /&gt;&lt;/p&gt;&#xD;
&lt;p&gt;&lt;strong&gt;安装LAMP环境&lt;/strong&gt;&lt;/p&gt;&#xD;
&lt;p&gt;Ubuntu的桌面版也可以安装&lt;a href="http://www.williamlong.info/archives/1908.html" target="_blank"&gt;LAMP&lt;/a&gt;（Linux + Apache + MySQL + PHP）环境，这里我介绍一个最简单的方法，就是使用XAMPP，这个项目我曾经在《&lt;a href="http://www.williamlong.info/archives/1281.html" target="_blank"&gt;常见的WAMP集成环境&lt;/a&gt;》中介绍过，XAMPP不但支持Windows，还支持Linux，&lt;a href="http://www.apachefriends.org/zh_cn/index.html" target="_blank"&gt;在其网站&lt;/a&gt;下载之后，运行下面两条命令：&lt;/p&gt;&#xD;
&lt;p&gt;tar xvfz xampp-linux-1.7.2.tar.gz -C /opt&lt;/p&gt;&#xD;
&lt;p&gt;/opt/lampp/lampp start&lt;/p&gt;&#xD;
&lt;p&gt;就可以启动&lt;a href="http://www.williamlong.info/archives/1908.html" target="_blank"&gt;LAMP&lt;/a&gt;环境，XAMPP是功能全面的集成环境，软件包中包含Apache、MySQL、SQLite、PHP、Perl、FileZilla FTP Server、Tomcat等等，很适合开发环境使用。&lt;/p&gt;&#xD;
&lt;p&gt;&lt;strong&gt;安装程序添加程序菜单和桌面&lt;/strong&gt;&lt;/p&gt;&#xD;
&lt;p&gt;有些程序是直接解压缩安装的，因此不会添加&amp;ldquo;应用程序&amp;rdquo;的菜单项，我们可以手动将其添加菜单项，具体方法是，打开&amp;ldquo;系统&amp;rdquo;&amp;mdash;&amp;ldquo;首选项&amp;rdquo;&amp;mdash;&amp;ldquo;主菜单&amp;rdquo;，新增即可。&lt;/p&gt;&#xD;
&lt;p&gt;添加桌面快捷方式是，在桌面上点右键，创建启动器。这个&amp;ldquo;启动器&amp;rdquo;就是Windows里面的&amp;ldquo;快捷方式&amp;rdquo;。&lt;/p&gt;&#xD;
&lt;p&gt;将&amp;ldquo;应用程序&amp;rdquo;的菜单项创建到桌面快捷方式的方法是，在&amp;ldquo;应用程序&amp;rdquo;的菜单项上单击鼠标右键，选择&amp;ldquo;将此启动器添加到桌面&amp;rdquo;或&amp;ldquo;将此启动器添加到面板&amp;rdquo;，就可以了。&lt;/p&gt;&#xD;
&lt;p&gt;以上是我在安装使用Ubuntu时整理的教程，如果你还没有安装过这个操作系统，相信在这个教程的指引下，你就能轻松驾驭这个Linux系统，如果你在使用Ubuntu的过程中也有一些经验和心得，请留言与大家分享。&lt;/p&gt;&#xD;
&lt;p&gt;&lt;/p&gt;&#xD;
&lt;p&gt;原创文章如转载，请注明：转载自&lt;a href="http://www.williamlong.info/"&gt;月光博客&lt;/a&gt; [ &lt;a href="http://www.williamlong.info/"&gt;http://www.williamlong.info/&lt;/a&gt; ]&#xD;
&lt;/p&gt;&#xD;
&lt;p&gt;&lt;/p&gt;&#xD;
&lt;p&gt;本文链接地址：&lt;a href="http://www.williamlong.info/archives/1905.html"&gt;http://www.williamlong.info/archives/1905.html&lt;/a&gt;&lt;/p&gt;&lt;img src="http://www.cnblogs.com/kaixin110/aggbug/1870113.html?type=1" width="1" height="1" alt=""/&gt;&lt;p&gt;&lt;a href="http://www.cnblogs.com/kaixin110/archive/2010/11/05/1870113.html" target="_blank"&gt;本文链接&lt;/a&gt;&lt;/p&gt;</content></entry><entry><id>http://www.cnblogs.com/kaixin110/archive/2010/11/05/1870093.html</id><title type="text">如何选择最适合的Linux版本</title><summary type="text">当你对别人说，&amp;ldquo;我要买辆车。&amp;rdquo;他马上就会问你：&amp;ldquo;什么车？&amp;rdquo;福特、丰田、还是本田？是双门跑车、小轿车、还是面包车？当然，还有其他类似的问题。 同样，如果你说&amp;ldquo;我想安装Linux！&amp;rdquo;你会被问到同样的问题：哪个Linux？没有一个纯粹概念上的&amp;ldquo;Linux&amp;rdquo;，这和没有一个&amp;ldquo;汽车&amp;rdquo;是一回事...</summary><published>2010-11-05T08:52:00Z</published><updated>2010-11-05T08:52:00Z</updated><author><name>kaixin110</name><uri>http://www.cnblogs.com/kaixin110/</uri></author><link rel="alternate" href="http://www.cnblogs.com/kaixin110/archive/2010/11/05/1870093.html"/><link rel="alternate" type="text/html" href="http://www.cnblogs.com/kaixin110/archive/2010/11/05/1870093.html"/><content type="html">&lt;p&gt;&lt;span style="font-family: 微软雅黑;"&gt;当你对别人说，&amp;ldquo;我要买辆车。&amp;rdquo;他马上就会问你：&amp;ldquo;什么车？&amp;rdquo;福特、丰田、还是本田？是双门跑车、小轿车、还是面包车？当然，还有其他类似的问题。   &lt;/span&gt;&lt;/p&gt;&#xD;
&lt;p&gt;&lt;span style="font-family: 微软雅黑;"&gt;同样，如果你说&amp;ldquo;我想安装Linux！&amp;rdquo;你会被问到同样的问题：哪个Linux？没有一个纯粹概念上的&amp;ldquo;Linux&amp;rdquo;，这和没有一个&amp;ldquo;汽车&amp;rdquo;是一回事。在某些方面，Linux和汽车是相同的：每辆汽车都有一个发动机，而所有的Linux版本都分享相同的Linux内核和GNU工具。  &lt;/span&gt;&lt;/p&gt;&#xD;
&lt;p&gt;&lt;span style="font-family: 微软雅黑;"&gt;不过，二者的最大相似可能也就到这种程度了&amp;mdash;&amp;mdash;事实上，选择一个正确的Linux版本比选择一辆汽车要复杂得多。现在你可以找到数百种&amp;mdash;&amp;mdash;如果不是上千种的&amp;mdash;&amp;mdash;Linux版本，它们全都运行良好并定期更新，这其中有许多是为了满足特定需求而编制的。&lt;/span&gt;&lt;/p&gt;&#xD;
&lt;p&gt;&lt;span style="font-family: 微软雅黑;"&gt;那么我们该如何选择？事实是，你不需要对每一种都详细了解。最好的方案是先搞清楚你的需求和兴趣，然后从三四个合适的Linux版本中挑选一个正确的。&lt;/span&gt;&lt;/p&gt;&#xD;
&lt;p&gt;&lt;span style="font-family: 微软雅黑;"&gt;我们没必要把所有的Linux版本列出来，那样也许会吓到你，在这里我们选出了大约20种最主流最高效的Linux版本，并按照常规的用户需求问题对它们分了组。如果你发现下面的问题正是你想问的，那么，你就很有可能在后面的描述中找到你所需要的Linux版本了。  &lt;/span&gt;&lt;/p&gt;&#xD;
&lt;p&gt;&lt;span style="font-family: 微软雅黑;"&gt;&lt;strong&gt;&amp;ldquo;我是新手，只是想开始使用Linux&amp;rdquo;&lt;/strong&gt;&lt;/span&gt;&lt;/p&gt;&#xD;
&lt;p&gt;&lt;span style="font-family: 微软雅黑;"&gt;对于从Windows转过来的新手而言，这个问题的答案显而易见：Ubuntu  Linux几乎是不二选择，非常容易上手。使用者可以将用户在Windows中的设置自动移植过来，比如他们的文档、个人设置包括Internet书签。用户甚至可以尝试各种无需改变硬件资源的安装方法：比如直接从光盘启动、与Windows同时启动、或直接在Windows分区中安装Ubuntu。Ubuntu的设计，以及它强大的社群支持，使其成为Linux快速入门的最佳选择。&lt;/span&gt;&lt;/p&gt;&#xD;
&lt;p&gt;&lt;span style="font-family: 微软雅黑;"&gt;尽管名气最大、用户也最多，但Ubuntu绝不是唯一可选的新手版。其他比如Linux  Mint（Ubuntu的衍生版本）、PCLinuxOS、SimplyMEPIS和Mandriva等等也都遵照&amp;ldquo;拿来即用&amp;rdquo;（"it should just  work"）的理念，采用各种不同的方法增强可用性、数据包管理能力和从Windows进行移植的能力。 &lt;/span&gt;&lt;/p&gt;&#xD;
&lt;p&gt;&lt;span style="font-family: 微软雅黑;"&gt;另一个应该提到的是Novell的openSUSE  11.1版，这也被公认为一个良好的Linux入门版本。免费的openSUSE来源于Novell的商业化版本SUSE  Linux，具有大量先进功能，如类似Windows Vista中那种舒适的可检索主目录，而且支持放入即自运行的测试体验盘（Live Disc）。 &lt;/span&gt;&lt;/p&gt;&#xD;
&lt;p&gt;&lt;span style="font-family: 微软雅黑;"&gt;&lt;strong&gt;&amp;ldquo;我已经用过Linux，想要更深入些&amp;rdquo;&lt;/strong&gt;&lt;/span&gt;&lt;/p&gt;&#xD;
&lt;p&gt;&lt;span style="font-family: 微软雅黑;"&gt;如果你已经熟悉Linux，或者你对自己的学习能力很有信心，我们可以接下来了解一些略为复杂的版本。&lt;/span&gt;&lt;/p&gt;&#xD;
&lt;p&gt;&lt;span style="font-family: 微软雅黑;"&gt;对于服务器和底层架构来说，红帽（Red  Hat）Linux是当仁不让的选择，由其社区支持开发的版本Fedora拥有同样强大的功能。它并不像Ubuntu那样经常更新但安装起来同样非常容易，也拥有同样吸引人的桌面特色。Linux之父Linus  Torvalds最近提到，他本人就是一个非常热心的Fedora用户。Fedora 10是最新的版本，更强大的Fedora 11的测试版也已经发布。&lt;/span&gt;&lt;/p&gt;&#xD;
&lt;p&gt;&lt;span style="font-family: 微软雅黑;"&gt;接下来是Debian，这很可能是所谓的ur-distro，作为其他如此之多的发行版（包括Ubuntu）都是以它为基础的。很多人不喜欢它漫长的开发周期；但值得称道的是它的稳定性，你可以用很久。Debian的最新版本是4.0，5.0版本正在研发中，什么时候能够公布呢？估计开发周期依然会过长。&lt;/span&gt;&lt;/p&gt;&#xD;
&lt;p&gt;&lt;span style="font-family: 微软雅黑;"&gt;&lt;strong&gt;&amp;ldquo;我只想给我的老机器装点最简单的&amp;rdquo;&lt;/strong&gt;&lt;/span&gt;&lt;/p&gt;&#xD;
&lt;p&gt;&lt;span style="font-family: 微软雅黑;"&gt;很多时候你只是需要一些基本的需求，Linux当然可以满足你。你可以找到可以在USB盘、光盘甚至完全在内存中运行的Linux版本。这里还应当指出，在内存或可移动存储器中运行Linux是一种很好的安全防护措施&amp;mdash;&amp;mdash;如果你生性多疑或者或者只是谨慎，你完全可以使用一个拇指大的U盘让你的计算机再无其他机密可谈。&lt;/span&gt;&lt;/p&gt;&#xD;
&lt;p&gt;&lt;span style="font-family: 微软雅黑;"&gt;Puppy  Linux是很多人的最爱，它虽然小，重量轻，但功能方面却非常完善。现在，在其4.1.2版本中，它仅仅使用了100MB就封装了几乎所有需要的功能，并且提供了额外的独立软件。对于一些逐渐老去的笔记本电脑来说，Puppy  Linux提供了近乎完美的方式，因为它只需要很少的空间或系统资源，能够很好地运行。 &lt;/span&gt;&lt;/p&gt;&#xD;
&lt;p&gt;&lt;span style="font-family: 微软雅黑;"&gt;与Puppy  Linux类似的版本还有TinyMe、功能削减版的PCLinuxOS、精简版的Ubuntu、Xubuntu，和仍在大力推广中的Moblin。在它们当中，Xubuntu可能是最成熟的，经过了广泛的测试，但Moblin具有闪电般的速度，拥有巨大的市场潜力。  &lt;/span&gt;&lt;/p&gt;&#xD;
&lt;p&gt;&lt;span style="font-family: 微软雅黑;"&gt;&lt;strong&gt;&amp;ldquo;我要在服务器上运行Linux&amp;rdquo;&lt;/strong&gt;&lt;/span&gt;&lt;/p&gt;&#xD;
&lt;p&gt;&lt;span style="font-family: 微软雅黑;"&gt;从一开始，Linux和服务器就是密不可分的。Linux在服务器的世界证明了自己，并将继续证明自己，各种版本的Linux在服务器的舞台上大展身手。&lt;/span&gt;&lt;/p&gt;&#xD;
&lt;p&gt;&lt;span style="font-family: 微软雅黑;"&gt;红帽Linux企业版，即著名的RHEL，仍然是服务器端最普遍的和受到最广泛支持的选择，但要注意它不是免费的，只提供红帽的签约客户（Fedora社区提供30天试用版）。&lt;/span&gt;&lt;/p&gt;&#xD;
&lt;p&gt;&lt;span style="font-family: 微软雅黑;"&gt;然而RHEL有一个有趣的变种，CentOS，它直接建立于RHEL的源代码之上，而且是免费提供的（但缺少官方支持）。因此一些拥有强大Linux技术团队的公司都选择了CentOS以节约成本，并按照内部需要做了大量修改。总之，如果你在RHEL上具有丰富经验，CentOS会是一个很好的选择。&lt;/span&gt;&lt;/p&gt;&#xD;
&lt;p&gt;&lt;span style="font-family: 微软雅黑;"&gt;另一种服务器版Linux近来获得了大量的积极关注，这是一种来源于Ubuntu的服务器版本，它的命名相当直白，Ubuntu Server  Edition。与RHEL不同，Ubuntu Server Edition是免费的，但不提供支持合同。 &lt;/span&gt;&lt;/p&gt;&#xD;
&lt;p&gt;&lt;span style="font-family: 微软雅黑;"&gt;&lt;strong&gt;&amp;ldquo;我遇到麻烦了&amp;rdquo;&lt;/strong&gt;&lt;/span&gt;&lt;/p&gt;&#xD;
&lt;p&gt;&lt;span style="font-family: 微软雅黑;"&gt;遇到什么麻烦了？系统无法开机，还是病毒感染了硬盘？没问题！在这种情况下，带有救援和恢复功能的Linux版本可以使我们在无需启动机器的情况下，直接读取硬盘，复制重要数据，也许还能进行修理。&lt;/span&gt;&lt;/p&gt;&#xD;
&lt;p&gt;&lt;span style="font-family: 微软雅黑;"&gt;大多数从Live CD启动的Linux版本都可以用作救援光盘，例如上面提过的小巧而轻便的版本。我个人最喜欢的是Puppy  Linux，它的启动速度飞快，用一个单独而清楚的菜单提供了多种工具。从技术角度而言，专门的SystemRescueCD会做得更好一些，它提供了各种先进的工具，可以修复系统及数据。&lt;/span&gt;&lt;/p&gt;&#xD;
&lt;p&gt;&lt;span style="font-family: 微软雅黑;"&gt;值得一提的还有Clonezilla，相当于Linux版的Norton  Ghost。它可以对你的分区或整个系统进行镜像操作。可以用它对系统进行备份，也同样可以克隆到多台机器中去。&lt;/span&gt;&lt;/p&gt;&#xD;
&lt;p&gt;&lt;span style="font-family: 微软雅黑;"&gt;&lt;strong&gt;最后的想法&lt;/strong&gt;&lt;/span&gt;&lt;/p&gt;&#xD;
&lt;p&gt;&lt;span style="font-family: 微软雅黑;"&gt;数目惊人的Linux版本也经常惹来争议，人们认为数量过多太难选择，反而阻碍Linux的发展，这也不无道理。是的，从这个意义上讲，一直没有一个权威的Linux版本，不可避免的造成了不同Linux阵营里的重复劳动。  &lt;/span&gt;&lt;/p&gt;&#xD;
&lt;p&gt;&lt;span style="font-family: 微软雅黑;"&gt;但是，从另一个角度来看，事情也没有那么复杂，由于开源理念，每个Linux版本做出的突破创新会被别的版本迅速吸收。而站在用户的位置上，因为Linux版本的针对性都很强，因此用户真正需要选择的版本也通常不超过两三个。在未来，Linux最终可能会在一个更大的超越Linux核心的基础上统一，但现在，它依然会百花齐放，等着你来选择。&lt;/span&gt;&lt;/p&gt;&lt;img src="http://www.cnblogs.com/kaixin110/aggbug/1870093.html?type=1" width="1" height="1" alt=""/&gt;&lt;p&gt;&lt;a href="http://www.cnblogs.com/kaixin110/archive/2010/11/05/1870093.html" target="_blank"&gt;本文链接&lt;/a&gt;&lt;/p&gt;</content></entry><entry><id>http://www.cnblogs.com/kaixin110/archive/2010/11/03/1868241.html</id><title type="text">PHP MYSQL 中文 乱码 终极解决方案,</title><summary type="text">连接字符集，当前环境的字符集，字段的字符集，以及你的原始数据的字符集。这些不统一，立刻就乱码在mysql里面，如果插入的字符集与当前环境和字段的不一致，在mysql显示就是乱码character_set_client | utf8character_set_connection | utf8character_set_database | utf8character_set_filesystem ...</summary><published>2010-11-03T09:08:00Z</published><updated>2010-11-03T09:08:00Z</updated><author><name>kaixin110</name><uri>http://www.cnblogs.com/kaixin110/</uri></author><link rel="alternate" href="http://www.cnblogs.com/kaixin110/archive/2010/11/03/1868241.html"/><link rel="alternate" type="text/html" href="http://www.cnblogs.com/kaixin110/archive/2010/11/03/1868241.html"/><content type="html">&lt;p&gt;连接字符集，当前环境的字符集，字段的字符集，以及你的原始数据的字符集。&#xD;
&lt;/p&gt;&#xD;
&lt;p&gt;&lt;/p&gt;&#xD;
&lt;p&gt;这些不统一，立刻就乱码&lt;/p&gt;&#xD;
&lt;p&gt;&lt;br /&gt;在mysql里面，如果插入的字符集与当前环境和字段的不一致，在mysql显示就是乱码&lt;/p&gt;&#xD;
&lt;p&gt;character_set_client&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; | utf8&lt;br /&gt;character_set_connection | utf8&lt;br /&gt;character_set_database&amp;nbsp;&amp;nbsp; | utf8&lt;br /&gt;character_set_filesystem | binary&lt;br /&gt;character_set_results&amp;nbsp;&amp;nbsp;&amp;nbsp; | utf8&lt;br /&gt;character_set_server&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; | utf8&lt;br /&gt;character_set_system&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; | utf8&lt;/p&gt;&#xD;
&lt;p&gt;&lt;/p&gt;&#xD;
&lt;p&gt;自己看吧，&lt;/p&gt;&#xD;
&lt;p&gt;php.ini my.ini&lt;/p&gt;&#xD;
&lt;p&gt;数据库编码&lt;/p&gt;&#xD;
&lt;p&gt;表编码&lt;/p&gt;&#xD;
&lt;p&gt;列编码&lt;/p&gt;&#xD;
&lt;p&gt;链接编码&lt;/p&gt;&#xD;
&lt;p&gt;&lt;/p&gt;&#xD;
&lt;p&gt;如果还是不行就发评论了吧&lt;/p&gt;&lt;img src="http://www.cnblogs.com/kaixin110/aggbug/1868241.html?type=1" width="1" height="1" alt=""/&gt;&lt;p&gt;&lt;a href="http://www.cnblogs.com/kaixin110/archive/2010/11/03/1868241.html" target="_blank"&gt;本文链接&lt;/a&gt;&lt;/p&gt;</content></entry><entry><id>http://www.cnblogs.com/kaixin110/archive/2010/11/03/1867832.html</id><title type="text">Javascript Widget入门解析</title><summary type="text">收到Erica的来信，希望知道采麦的Widget是怎么做出来的，突然想起当年我第一次写widget代码的时候，也是满世界找不到一个简明实用的教程。于是做个总结，也许更多人可以用得到。复习一下两个js函数：js可以动态生成网页代码，比如：document.write(&amp;rsquo;&amp;lt;div id=&amp;rdquo;photo&amp;rdquo;&amp;gt;123&amp;lt;/div&amp;gt;&amp;rsquo;); 这...</summary><published>2010-11-03T02:53:00Z</published><updated>2010-11-03T02:53:00Z</updated><author><name>kaixin110</name><uri>http://www.cnblogs.com/kaixin110/</uri></author><link rel="alternate" href="http://www.cnblogs.com/kaixin110/archive/2010/11/03/1867832.html"/><link rel="alternate" type="text/html" href="http://www.cnblogs.com/kaixin110/archive/2010/11/03/1867832.html"/><content type="html">&lt;p&gt;收到Erica的来信，希望知道采麦的Widget是怎么做出来的，突然想起当年我第一次写widget代码的时候，也是满世界找不到一个简明实用的教程。于是做个总结，也许更多人可以用得到。&lt;/p&gt;&#xD;
&lt;p&gt;&lt;strong&gt;复习一下两个js函数：&lt;/strong&gt;&lt;/p&gt;&#xD;
&lt;p&gt;js可以动态生成网页代码，比如：&lt;/p&gt;&#xD;
&lt;p&gt;&lt;em&gt;document.write(&amp;rsquo;&amp;lt;div id=&amp;rdquo;photo&amp;rdquo;&amp;gt;123&amp;lt;/div&amp;gt;&amp;rsquo;); &lt;/em&gt;&lt;/p&gt;&#xD;
&lt;p&gt;这段代码可以让网页里显示出一个叫photo的层，里面还有数字123。&lt;/p&gt;&#xD;
&lt;p&gt;此外，js可以动态改变网页内容，比如这段代码：&lt;/p&gt;&#xD;
&lt;p&gt;&lt;em&gt;document.getElementById(&amp;rsquo;photo&amp;rsquo;).innerHTML=&amp;rsquo;abc&amp;rsquo;; &lt;/em&gt;&lt;/p&gt;&#xD;
&lt;p&gt;就可以让这个photo层里显示abc，而不是原来的123了&lt;/p&gt;&#xD;
&lt;p&gt;别看这么一段小代码，其实这就是整个widget的核心了&lt;/p&gt;&#xD;
&lt;p&gt;&lt;strong&gt;技术原理：&lt;/strong&gt;&lt;/p&gt;&#xD;
&lt;p&gt;widget有3个重要部分组成：数据、外壳、脚本。&lt;/p&gt;&#xD;
&lt;ul&gt;&#xD;
&lt;li&gt;&lt;strong&gt;数据&lt;/strong&gt;：就是你希望显示出来的内容，比如你要显示flickr上最近的照片，那么照片就是数据；&lt;/li&gt;&#xD;
&lt;li&gt;&lt;strong&gt;外壳&lt;/strong&gt;：就是容纳数据的容器，比如上述照片，你把他们包裹到一个叫photo的div里，那么这个div就是外壳。&lt;/li&gt;&#xD;
&lt;li&gt;&lt;strong&gt;脚本&lt;/strong&gt;：脚本的作用是生成外壳，并把数据填充到外壳里，主要就是js代码，当然也可以带一些css&lt;/li&gt;&#xD;
&lt;/ul&gt;&#xD;
&lt;p&gt;所以，理论上，一个原始的widget代码应该是这样的：&lt;/p&gt;&#xD;
&lt;p&gt;&lt;em&gt;&amp;lt;script type=&amp;rdquo;text/javascript&amp;rdquo;&amp;gt;//调用js脚本&lt;/em&gt;&lt;/p&gt;&#xD;
&lt;p&gt;&lt;em&gt;document.write(&amp;rsquo;&amp;lt;div id=&amp;rdquo;photo&amp;rdquo;&amp;gt;&amp;lt;/div&amp;gt;&amp;rsquo;); //js脚本生成外壳photo&lt;br /&gt;&lt;/em&gt;&lt;/p&gt;&#xD;
&lt;p&gt;&lt;em&gt;document.getElementById(&amp;rsquo;photo&amp;rsquo;).innerHTML=&amp;rsquo;abc&amp;rsquo;; //js脚本把数据abc填充到外壳photo&lt;br /&gt;&lt;/em&gt;&lt;/p&gt;&#xD;
&lt;p&gt;&lt;em&gt;&amp;lt;/script&amp;gt;&lt;/em&gt;&lt;/p&gt;&#xD;
&lt;p&gt;是不是很简单？是很简单，可惜太长了，于是把上面四行代码的中间两行提取出来，复制放到一个wjs.js文件里：&lt;/p&gt;&#xD;
&lt;p&gt;&lt;em&gt;document.write(&amp;rsquo;&amp;lt;div id=&amp;rdquo;photo&amp;rdquo;&amp;gt;&amp;lt;/div&amp;gt;&amp;rsquo;); //js脚本生成外壳photo&lt;br /&gt;&lt;/em&gt;&lt;/p&gt;&#xD;
&lt;p&gt;&lt;em&gt;document.getElementById(&amp;rsquo;photo&amp;rsquo;).innerHTML=&amp;rsquo;abc&amp;rsquo;; //js脚本把数据abc填充到外壳photo&lt;/em&gt;&lt;/p&gt;&#xD;
&lt;p&gt;这样只需要调用一下就可以使用widget了：&lt;/p&gt;&#xD;
&lt;p&gt;&lt;em&gt;&amp;lt;script type=&amp;rdquo;text/javascript&amp;rdquo; src=&amp;rdquo;wjs.js&amp;rdquo;&amp;gt;&amp;lt;/script&amp;gt; &lt;/em&gt;&lt;/p&gt;&#xD;
&lt;p&gt;好了，到这里你已经学会了最简单的widget制作，快去实验一下吧。&lt;/p&gt;&#xD;
&lt;p&gt;&lt;strong&gt;基础进阶：&lt;/strong&gt;&lt;/p&gt;&#xD;
&lt;p&gt;那么，如果数据不是abc怎么办呢？ 很简单，把数据独立出来就可以了。我们改造一下wjs.js代码：&lt;/p&gt;&#xD;
&lt;p&gt;&lt;em&gt;document.write(&amp;rsquo;&amp;lt;div id=&amp;rdquo;photo&amp;rdquo;&amp;gt;&amp;lt;/div&amp;gt;&amp;rsquo;);&amp;nbsp;&amp;nbsp; //利用js建立photo层，生成外壳&lt;br /&gt;&lt;/em&gt;&lt;em&gt;document.write(&amp;rsquo;&amp;lt;script type=&amp;rdquo;text/javascript&amp;rdquo; src=&amp;rdquo;widget.js&amp;rdquo;&amp;gt;&amp;lt;/script&amp;gt;&amp;rsquo;);&amp;nbsp;//js填充数据&lt;/em&gt;&lt;/p&gt;&#xD;
&lt;p&gt;数据就在&lt;em&gt;widget.js&lt;/em&gt;里，我们分析一下其代码，只有一句：&lt;/p&gt;&#xD;
&lt;p&gt;&lt;em&gt;document.getElementById(&amp;rsquo;photo&amp;rsquo;).innerHTML=&amp;rsquo;xxx&amp;rsquo;;&lt;/em&gt;&lt;/p&gt;&#xD;
&lt;p&gt;这样的话，要改变数据，只需要把widget.js里的xxx换成任何内容即可，而无需改动wjs.js&lt;/p&gt;&#xD;
&lt;p&gt;&lt;strong&gt;中级进阶：&lt;/strong&gt;&lt;/p&gt;&#xD;
&lt;p&gt;如果要自动动态改变数据xxx，只需要把widget.js也做成动态的，以php为例，首先把wjs.js修改一下：&lt;/p&gt;&#xD;
&lt;p&gt;&lt;em&gt;document.write(&amp;rsquo;&amp;lt;div id=&amp;rdquo;photo&amp;rdquo;&amp;gt;&amp;lt;/div&amp;gt;&amp;rsquo;);&amp;nbsp;&amp;nbsp; //利用js建立photo层，生成外壳&lt;/em&gt;&lt;/p&gt;&#xD;
&lt;p&gt;&lt;em&gt;document.write(&amp;rsquo;&amp;lt;script type=&amp;rdquo;text/javascript&amp;rdquo; src=&amp;rdquo;widget.php?user=howard&amp;gt;&amp;lt;/script&amp;gt;&amp;rsquo;); &lt;/em&gt;&lt;em&gt;//js填充数据&lt;/em&gt;&lt;/p&gt;&#xD;
&lt;p&gt;注意里面的widget.js换成了widget.php，后面还跟了一串变量，这样就可以显示为howard量身定制的数据了，看看widget.php的代码：&lt;/p&gt;&#xD;
&lt;p&gt;&lt;em&gt;&amp;lt;?php&lt;br /&gt;&lt;/em&gt; &lt;em&gt;Header( &amp;ldquo;Content-type: text/javascript&amp;rdquo;); //声明文件类型为js&lt;br /&gt;&lt;/em&gt;&lt;/p&gt;&#xD;
&lt;p&gt;&lt;em&gt;$user=$_GET['user']; //读取user变量 (howard)&lt;br /&gt;&lt;/em&gt;&lt;/p&gt;&#xD;
&lt;p&gt;&lt;em&gt;echo &amp;ldquo;document.getElementById(&amp;rsquo;photo&amp;rsquo;).innerHTML=&amp;rsquo;hi, my name is $user&amp;rsquo;; &amp;ldquo;;&lt;/em&gt;&lt;/p&gt;&#xD;
&lt;p&gt;&lt;em&gt;//输出动态内容(hi, my name is howard)&lt;br /&gt;&lt;/em&gt;&lt;/p&gt;&#xD;
&lt;p&gt;&lt;em&gt;?&amp;gt;&lt;/em&gt;&lt;/p&gt;&#xD;
&lt;p&gt;到这里，我们已经可以根据不同变量来自动显示不同的数据了。后面就很简单了，把widget.php任意改造，读取数据库，可以输出各种各样关于howard的数据。&lt;/p&gt;&#xD;
&lt;p&gt;&lt;strong&gt;实战应用：&lt;/strong&gt;&lt;/p&gt;&#xD;
&lt;p&gt;事实上，实际应用中，wjs.js也被改造成了动态文件，比如wsj.php，这样你的用户howard只需要在其blog里插入以下代码，就可以真正实现个性数据调用：&lt;/p&gt;&#xD;
&lt;p&gt;&lt;em&gt;&amp;lt;script type=&amp;rdquo;text/javascript&amp;rdquo; src=&amp;rdquo;http://domain.com/wjs.php?user=howard&amp;rdquo;&amp;gt; &amp;lt;/script&amp;gt; &lt;/em&gt;&lt;/p&gt;&#xD;
&lt;p&gt;wjs.php的内部代码是这样的：&lt;/p&gt;&#xD;
&lt;p&gt;&lt;em&gt;&amp;lt;?php&lt;br /&gt;&lt;/em&gt; &lt;em&gt;Header( &amp;ldquo;Content-type: text/javascript&amp;rdquo;); //声明文件类型为js&lt;br /&gt;&lt;/em&gt;&lt;/p&gt;&#xD;
&lt;p&gt;&lt;em&gt;$user=$_GET['user']; //读取user变量 (howard)&lt;br /&gt;&lt;/em&gt;&lt;/p&gt;&#xD;
&lt;p&gt;&lt;em&gt;echo &amp;ldquo;document.write(&amp;rsquo;&amp;lt;div id=&amp;rdquo;photo&amp;rdquo;&amp;gt;&amp;lt;/div&amp;gt;&amp;rsquo;);&amp;rdquo; &amp;nbsp; //利用js建立photo层，生成外壳&lt;/em&gt;&lt;/p&gt;&#xD;
&lt;p&gt;&lt;em&gt;echo &amp;ldquo;document.write(&amp;rsquo;&lt;em&gt;&amp;lt;script type=\&amp;rdquo;text/javascript\&amp;rdquo; src=\&amp;rdquo;widget.php?user=$user\&lt;/em&gt;&lt;em&gt;&amp;rdquo;&lt;/em&gt;&lt;em&gt;&amp;gt;&lt;/em&gt;&lt;em&gt;&amp;lt;/script&amp;gt;); &amp;ldquo;; //动态调用widget.php&lt;/em&gt;&lt;/em&gt;&lt;/p&gt;&#xD;
&lt;p&gt;&lt;em&gt;?&amp;gt;&lt;/em&gt;&lt;/p&gt;&#xD;
&lt;p&gt;这样，widget.php收到了user变量之后，就能显示出howard的个性数据。&lt;/p&gt;&#xD;
&lt;p&gt;先写到这，大家可以先回去测试一下。真正能用的widget，代码和上面有很大区别，但是原理是相同的。&lt;/p&gt;&lt;img src="http://www.cnblogs.com/kaixin110/aggbug/1867832.html?type=1" width="1" height="1" alt=""/&gt;&lt;p&gt;&lt;a href="http://www.cnblogs.com/kaixin110/archive/2010/11/03/1867832.html" target="_blank"&gt;本文链接&lt;/a&gt;&lt;/p&gt;</content></entry><entry><id>http://www.cnblogs.com/kaixin110/archive/2010/11/02/1866916.html</id><title type="text">深入了解php.ini</title><summary type="text">;;;;;;;;;;;;;;;;;;; 关于php.ini ;;;;;;;;;;;;;;;;;;;; 这个文件必须命名为'php.ini'并放置在httpd.conf中PHPINIDir指令指定的目录中。; 最新版本的php.ini可以在下面两个位置查看：; http://cvs.php.net/viewvc.cgi/php-src/php.ini-recommended?view=co; htt...</summary><published>2010-11-02T02:48:00Z</published><updated>2010-11-02T02:48:00Z</updated><author><name>kaixin110</name><uri>http://www.cnblogs.com/kaixin110/</uri></author><link rel="alternate" href="http://www.cnblogs.com/kaixin110/archive/2010/11/02/1866916.html"/><link rel="alternate" type="text/html" href="http://www.cnblogs.com/kaixin110/archive/2010/11/02/1866916.html"/><content type="html">&lt;p&gt;;;;;;;;;;;;;;;;;;&lt;br /&gt;;; 关于php.ini ;;&lt;br /&gt;;;;;;;;;;;;;;;;;;&lt;br /&gt;; 这个&lt;span &gt;文件&lt;/span&gt;必须命名为'php.ini'并放置在httpd.conf中&lt;span &gt;PHP&lt;/span&gt;INIDir指令指定的&lt;span &gt;目录&lt;/span&gt;中。&lt;br /&gt;; 最新版本的php.ini可以在下面两个位置查看：&lt;br /&gt;; &lt;a href="http://cvs.php.net/viewvc.cgi/php-src/php.ini-recommended?view=co" target="_blank"&gt;http://cvs.php.net/viewvc.cgi/php-src/php.ini-recommended?view=co&lt;/a&gt;&lt;br /&gt;; &lt;a href="http://cvs.php.net/viewvc.cgi/php-src/php.ini-dist?view=co" target="_blank"&gt;http://cvs.php.net/viewvc.cgi/php-src/php.ini-dist?view=co&lt;/a&gt;&lt;/p&gt;&#xD;
&lt;p&gt;&lt;/p&gt;&#xD;
&lt;p&gt;&lt;br /&gt;;;;;;;;;;;;;&lt;br /&gt;;;&amp;nbsp;&amp;nbsp;语法&amp;nbsp;&amp;nbsp;;;&lt;br /&gt;;;;;;;;;;;;;&lt;br /&gt;; 该文件的语法非常简单。空白字符和以分号开始的行被简单地忽略。&lt;br /&gt;; 章节标题(例如: [php])也被简单地忽略，即使将来它们可能有某种意义。&lt;br /&gt;;&lt;br /&gt;; &lt;span &gt;设置&lt;/span&gt;指令的格式如下：&lt;br /&gt;; directive = value&lt;br /&gt;; 指令名(directive)是大小写敏感的！所以"foo=bar"不同于"FOO=bar"。&lt;br /&gt;; 值(value)可以是：&lt;br /&gt;; 1. 用引号界定的字符串(如："foo")&lt;br /&gt;; 2. 一个数字(整数或浮点数，如：0, 1, 34, -1, 33.55)&lt;br /&gt;; 3. 一个PHP常量(如：E_ALL, M_PI)&lt;br /&gt;; 4. 一个INI常量(On, Off, none)&lt;br /&gt;; 5. 一个表达式(如：E_ALL &amp;amp; ~E_&lt;span &gt;NOT&lt;/span&gt;ICE)&lt;br /&gt;;&lt;br /&gt;; INI文件中的表达式仅使用：位运算符、逻辑非、圆括号：&lt;br /&gt;; | 位或&lt;br /&gt;; &amp;amp; 位与&lt;br /&gt;; ~ 位非&lt;br /&gt;; ! 逻辑非&lt;br /&gt;;&lt;br /&gt;; 布尔标志用 On 表示打开，用 Off 表示关闭。&lt;br /&gt;;&lt;br /&gt;; 一个空字符串可以用在等号后不写任何东西表示，或者用 none 关键字：&lt;br /&gt;; foo =&amp;nbsp; &amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp; &amp;nbsp;; 将foo设为空字符串&lt;br /&gt;; foo = none&amp;nbsp; &amp;nbsp; ; 将foo设为空字符串&lt;br /&gt;; foo = "none"&amp;nbsp;&amp;nbsp;; 将foo设为字符串'none'&lt;br /&gt;;&lt;br /&gt;; 如果你在指令值中使用动态扩展(PHP扩展或Zend扩展)中的常量，&lt;br /&gt;; 那么你只能在加载这些动态扩展的指令行之后使用这些常量。&lt;/p&gt;&#xD;
&lt;p&gt;&lt;br /&gt;;;;;;;;;;;;;;;;;;;&lt;br /&gt;;;&amp;nbsp;&amp;nbsp;httpd.conf&amp;nbsp;&amp;nbsp;;;&lt;br /&gt;;;;;;;;;;;;;;;;;;;&lt;br /&gt;; 可以在httpd.conf中针对特定虚拟主机或目录覆盖php.ini的值，以进行更灵活的配置：&lt;br /&gt;; php_admin_value name value&amp;nbsp;&amp;nbsp;;设置非bool型的指令，将value设为none则清除先前的设定&lt;br /&gt;; php_admin_flag&amp;nbsp;&amp;nbsp;name on|off ;仅用于设置bool型的指令&lt;br /&gt;; [&lt;span &gt;提示&lt;/span&gt;]因为很多指令不允许使用php_value/php_flag进行设置，因此不&lt;span &gt;建议&lt;/span&gt;使用这两个。&lt;br /&gt;;&lt;br /&gt;; PHP常量(如E_ALL)仅能在php.ini中使用，在httpd.conf中必须使用相应的掩码值。&lt;/p&gt;&#xD;
&lt;p&gt;;[2008-3-2日更新]&lt;br /&gt;;==========================================================================================&lt;br /&gt;;;=====================================配置指令详解========================================&lt;br /&gt;;==========================================================================================&lt;br /&gt;; 以下每个指令的设定值都与 PHP-5.2.5 内建的默认值相同。&lt;br /&gt;; 也就是说，如果'php.ini'不存在，或者你删掉了某些行，默认值与之相同。&lt;/p&gt;&#xD;
&lt;p&gt;;;;;;;;;;;;;;;&lt;br /&gt;;;&amp;nbsp;&amp;nbsp;Apache&amp;nbsp;&amp;nbsp;;;&lt;br /&gt;;;;;;;;;;;;;;;&lt;br /&gt;[Apache]&lt;br /&gt;; 仅在将PHP作为Apache模块时才有效。&lt;/p&gt;&#xD;
&lt;p&gt;child_terminate = Off&lt;br /&gt;; PHP脚本在请求结束后是否允许使用apache_child_terminate()&lt;span &gt;函数&lt;/span&gt;终止子进程。&lt;br /&gt;; 该指令仅在UNIX平台上将PHP安装为Apache1.3的模块时可用。其他情况下皆不存在。&lt;/p&gt;&#xD;
&lt;p&gt;engine = On&lt;br /&gt;; 是否启用PHP解析引擎。&lt;br /&gt;; 提示：可以在httpd.conf中基于目录或者虚拟主机来打开或者关闭PHP解析引擎。&lt;/p&gt;&#xD;
&lt;p&gt;last_modified = Off&lt;br /&gt;; 是否在Last-Modified应答头中放置该PHP脚本的最后修改时间。&lt;/p&gt;&#xD;
&lt;p&gt;xbithack = Off&lt;br /&gt;; 是否不管文件结尾是什么，都作为PHP可执行位组来解析。&lt;/p&gt;&#xD;
&lt;p&gt;&lt;br /&gt;;;;;;;;;;;;;;;;&lt;br /&gt;;;&amp;nbsp;&amp;nbsp;PHP核心&amp;nbsp;&amp;nbsp;;;&lt;br /&gt;;;;;;;;;;;;;;;;&lt;/p&gt;&#xD;
&lt;p&gt;[PHP-Core-DateTime]&lt;br /&gt;; 前四个配置选&lt;span &gt;项目&lt;/span&gt;前仅用于date_sunrise()和date_sunset()函数。&lt;/p&gt;&#xD;
&lt;p&gt;date.default_latitude = 31.7667&lt;br /&gt;; 默认纬度&lt;/p&gt;&#xD;
&lt;p&gt;date.default_longitude = 35.2333&lt;br /&gt;; 默认经度&lt;/p&gt;&#xD;
&lt;p&gt;date.sunrise_zenith = 90.583333&lt;br /&gt;; 默认日出天顶&lt;/p&gt;&#xD;
&lt;p&gt;date.sunset_zenith = 90.583333&lt;br /&gt;; 默认日落天顶&lt;/p&gt;&#xD;
&lt;p&gt;date.timezone =&lt;br /&gt;; 未设定TZ环境变量时用于所有日期和时间函数的默认时区。&lt;br /&gt;; 中国大陆应当使用"&lt;img src="http://qeephp.com/bbs/images/smilies/default/titter.gif" border="0" alt="" /&gt;RC"&lt;br /&gt;; &lt;span &gt;应用&lt;/span&gt;时区的优先顺序为：&lt;br /&gt;; 1. 用date_default_timezone_set()函数设定的时区(如果设定了的话)&lt;br /&gt;; 2. TZ 环境变量(如果非空的话)&lt;br /&gt;; 3. 该指令的值(如果设定了的话)&lt;br /&gt;; 4. PHP自己推测(如果操作&lt;span &gt;系统&lt;/span&gt;支持)&lt;br /&gt;; 5. 如果以上都不成功，则使用 "UTC"&lt;/p&gt;&#xD;
&lt;p&gt;&lt;br /&gt;[PHP-Core-Assert]&lt;/p&gt;&#xD;
&lt;p&gt;assert.active = On&lt;br /&gt;; 是否启用assert()断言评估&lt;/p&gt;&#xD;
&lt;p&gt;assert.bail = Off&lt;br /&gt;; 是否在发生失败断言时中止脚本的执行&lt;/p&gt;&#xD;
&lt;p&gt;assert.callback =&lt;br /&gt;; 发生失败断言时执行的回调函数&lt;/p&gt;&#xD;
&lt;p&gt;assert.quiet_eval = Off&lt;br /&gt;; 是否使用安静评估(不显示任何错误信息，相当于error_reporting=0)。&lt;br /&gt;; 若关闭则在评估断言表达式的时候使用当前的error_reporting指令值。&lt;/p&gt;&#xD;
&lt;p&gt;assert.warning = On&lt;br /&gt;; 是否对每个失败断言都发出警告&lt;/p&gt;&#xD;
&lt;p&gt;&lt;br /&gt;[PHP-Core-SafeMode]&lt;br /&gt;; 安全&lt;span &gt;模式&lt;/span&gt;是为了&lt;span &gt;解决&lt;/span&gt;共享服务器的安全问题而设立的。&lt;br /&gt;; 但试图在PHP层解决这个问题在结构上是不合理的，&lt;br /&gt;; 正确的做法应当是修改web服务器层和操作系统层。&lt;br /&gt;; 因此在PHP6中废除了安全模式，并使用基于open_basedir的安全防护。&lt;br /&gt;; 此部分指令在PHP6中已经全部被删除。&lt;/p&gt;&#xD;
&lt;p&gt;safe_mode = Off&lt;br /&gt;; 是否启用安全模式。&lt;br /&gt;; 打开时，PHP将检查当前脚本的拥有者是否和被操作的文件的拥有者相同，&lt;br /&gt;; 相同则允许操作，不同则拒绝操作。&lt;/p&gt;&#xD;
&lt;p&gt;safe_mode_gid = Off&lt;br /&gt;; 在安全模式下，默认在&lt;span &gt;访问&lt;/span&gt;文件时会做UID比较检查。&lt;br /&gt;; 但有些情况下严格的UID检查反而是不适合的，宽松的GID检查已经足够。&lt;br /&gt;; 如果你想将其放宽到仅做GID比较，可以打开这个&lt;span &gt;参数&lt;/span&gt;。&lt;/p&gt;&#xD;
&lt;p&gt;safe_mode_allowed_env_vars = "&lt;img src="http://qeephp.com/bbs/images/smilies/default/titter.gif" border="0" alt="" /&gt;HP_"&lt;br /&gt;; 在安全模式下，&lt;span &gt;用户&lt;/span&gt;仅可以更改的环境变量的前缀列表(逗号分隔)。&lt;br /&gt;; 允许用户设置某些环境变量，可能会导致潜在的安全漏洞。&lt;br /&gt;; 注意: 如果这一参数值为空，PHP将允许用户更改任意环境变量！&lt;/p&gt;&#xD;
&lt;p&gt;safe_mode_protected_env_vars = "LD_LIBRARY_PATH"&lt;br /&gt;; 在安全模式下，用户不能更改的环境变量列表(逗号分隔)。&lt;br /&gt;; 这些变量即使在safe_mode_allowed_env_vars指令设置为允许的情况下也会得到保护。&lt;/p&gt;&#xD;
&lt;p&gt;safe_mode_exec_dir = "/usr/local/php/bin"&lt;br /&gt;; 在安全模式下，只有该目录下的可执行&lt;span &gt;程序&lt;/span&gt;才允许被执行系统程序的函数执行。&lt;br /&gt;; 这些函数是：system, escapeshellarg, escapeshellcmd, exec, passthru,&lt;br /&gt;; proc_close, proc_get_status, proc_nice, proc_open, proc_terminate, shell_exec&lt;/p&gt;&#xD;
&lt;p&gt;safe_mode_include_dir =&lt;br /&gt;; 在安全模式下，该组目录和其子目录下的文件被包含时，将跳过UID/GID检查。&lt;br /&gt;; 换句话说，如果此处的值为空，任何UID/GID不符合的文件都不允许被包含。&lt;br /&gt;; 这里设置的目录必须已经存在于include_path指令中或者用完整路径来包含。&lt;br /&gt;; 多个目录之间用冒号(Win下为分号)隔开。&lt;br /&gt;; 指定的限制实际上是一个前缀，而非一个目录名，&lt;br /&gt;; 也就是说"/dir/incl"将允许访问"/dir/include"和"/dir/incls"&lt;br /&gt;; 如果您希望将访问控制在一个指定的目录，那么请在结尾加上斜线。&lt;/p&gt;&#xD;
&lt;p&gt;&lt;br /&gt;[PHP-Core-Safe]&lt;/p&gt;&#xD;
&lt;p&gt;allow_&lt;span &gt;url&lt;/span&gt;_fopen = On&lt;br /&gt;; 是否允许打开远程文件&lt;/p&gt;&#xD;
&lt;p&gt;allow_url_include = Off&lt;br /&gt;; 是否允许include/require远程文件。&lt;/p&gt;&#xD;
&lt;p&gt;disable_classes =&lt;br /&gt;; 该指令接受一个用逗号分隔的类名列表，以禁用特定的类。&lt;/p&gt;&#xD;
&lt;p&gt;disable_functions =&lt;br /&gt;; 该指令接受一个用逗号分隔的函数名列表，以禁用特定的函数。&lt;/p&gt;&#xD;
&lt;p&gt;enable_dl = On&lt;br /&gt;; 是否允许使用dl()函数。dl()函数仅在将PHP作为apache模块安装时才有效。&lt;br /&gt;; 禁用dl()函数主要是出于安全考虑，因为它可以绕过open_basedir指令的限制。&lt;br /&gt;; 在安全模式下始终禁用dl()函数，而不管此处如何设置。&lt;br /&gt;; PHP6中删除了该指令，相当于设为Off。&lt;/p&gt;&#xD;
&lt;p&gt;expose_php = On&lt;br /&gt;; 是否暴露PHP被安装在服务器上的事实(在http头中加上其签名)。&lt;br /&gt;; 它不会有安全上的直接威胁，但它使得客户端知道服务器上安装了PHP。&lt;/p&gt;&#xD;
&lt;p&gt;open_basedir =&lt;br /&gt;; 将PHP允许操作的所有文件(包括文件自身)都限制在此组目录列表下。&lt;br /&gt;; 当一个脚本试图打开一个指定目录树之外的文件时，将遭到拒绝。&lt;br /&gt;; 所有的符号连接都会被解析，所以不可能通过符号连接来避开此限制。&lt;br /&gt;; 特殊值'.'指定了存放该脚本的目录将被当做基准目录，&lt;br /&gt;; 但这有些危险，因为脚本的工作目录可以轻易被chdir()改变。&lt;br /&gt;; 对于共享服务器，在httpd.conf中针对不同的虚拟主机或目录灵活设置该指令将变得非常有用。&lt;br /&gt;; 在Windows中用分号分隔目录，UNIX系统中用冒号分隔目录。&lt;br /&gt;; 作为Apache模块时，父目录中的open_basedir路径将&lt;span &gt;自动&lt;/span&gt;被继承。&lt;br /&gt;; 指定的限制实际上是一个前缀，而非一个目录名，&lt;br /&gt;; 也就是说"/dir/incl"将允许访问"/dir/include"和"/dir/incls"，&lt;br /&gt;; 如果您希望将访问控制在一个指定的目录，那么请在结尾加上一个斜线。&lt;br /&gt;; 默认是允许打开所有文件。&lt;/p&gt;&#xD;
&lt;p&gt;sql.safe_mode = Off&lt;br /&gt;; 是否使用&lt;span &gt;SQL&lt;/span&gt;安全模式。&lt;br /&gt;; 如果打开，指定默认值的&lt;span &gt;数据库&lt;/span&gt;连接函数将会使用这些默认值代替支持的参数。&lt;br /&gt;; 对于每个不同&lt;span &gt;数据&lt;/span&gt;库的连接函数，其默认值请参考相应的&lt;span &gt;手册&lt;/span&gt;&lt;span &gt;页面&lt;/span&gt;。&lt;/p&gt;&#xD;
&lt;p&gt;&lt;br /&gt;[PHP-Core-Error]&lt;/p&gt;&#xD;
&lt;p&gt;error_reporting = E_ALL &amp;amp; ~E_NOTICE&lt;br /&gt;; 错误报告级别是位&lt;span &gt;字段&lt;/span&gt;的叠加，推荐使用 E_ALL | E_STRICT&lt;br /&gt;;&amp;nbsp; &amp;nbsp; 1&amp;nbsp;&amp;nbsp;E_ERROR&amp;nbsp; &amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp; &amp;nbsp; 致命的&lt;span &gt;运行&lt;/span&gt;时错误&lt;br /&gt;;&amp;nbsp; &amp;nbsp; 2&amp;nbsp;&amp;nbsp;E_WARNING&amp;nbsp; &amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp;运行时警告(非致命性错误)&lt;br /&gt;;&amp;nbsp; &amp;nbsp; 4&amp;nbsp;&amp;nbsp;E_PARSE&amp;nbsp; &amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp; &amp;nbsp; 编译时解析错误&lt;br /&gt;;&amp;nbsp; &amp;nbsp; 8&amp;nbsp;&amp;nbsp;E_NOTICE&amp;nbsp; &amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp; &amp;nbsp;运行时提醒(经常是&lt;span &gt;bug&lt;/span&gt;，也可能是有意的)&lt;br /&gt;;&amp;nbsp; &amp;nbsp;16&amp;nbsp;&amp;nbsp;E_CORE_ERROR&amp;nbsp; &amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp;PHP启动时初始化过程中的致命错误&lt;br /&gt;;&amp;nbsp; &amp;nbsp;32&amp;nbsp;&amp;nbsp;E_CORE_WARNING&amp;nbsp; &amp;nbsp;&amp;nbsp; &amp;nbsp;PHP启动时初始化过程中的警告(非致命性错)&lt;br /&gt;;&amp;nbsp; &amp;nbsp;64&amp;nbsp;&amp;nbsp;E_COMPILE_ERROR&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp;编译时致命性错&lt;br /&gt;;&amp;nbsp;&amp;nbsp;128&amp;nbsp;&amp;nbsp;E_COMPILE_WARNING&amp;nbsp; &amp;nbsp;编译时警告(非致命性错)&lt;br /&gt;;&amp;nbsp;&amp;nbsp;256&amp;nbsp;&amp;nbsp;E_USER_ERROR&amp;nbsp; &amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp;用户自&lt;span &gt;定义&lt;/span&gt;的致命错误&lt;br /&gt;;&amp;nbsp;&amp;nbsp;512&amp;nbsp;&amp;nbsp;E_USER_WARNING&amp;nbsp; &amp;nbsp;&amp;nbsp; &amp;nbsp;用户自定义的警告(非致命性错误)&lt;br /&gt;; 1024&amp;nbsp;&amp;nbsp;E_USER_NOTICE&amp;nbsp; &amp;nbsp;&amp;nbsp; &amp;nbsp; 用户自定义的提醒(经常是bug，也可能是有意的)&lt;br /&gt;; 2048&amp;nbsp;&amp;nbsp;E_STRICT&amp;nbsp; &amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp; &amp;nbsp;编码标准化警告(建议如何修改以向前兼容)&lt;br /&gt;; 4096&amp;nbsp;&amp;nbsp;E_RECOVERABLE_ERROR 接近致命的运行时错误，若未被捕获则视同E_ERROR&lt;br /&gt;; 6143&amp;nbsp;&amp;nbsp;E_ALL&amp;nbsp; &amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp; &amp;nbsp;除E_STRICT外的所有错误(PHP6中为8191,即包含所有)&lt;br /&gt;; 也可以用2147483647(所有二进制位全为1)打开现在或将来可能出现的各种错误&lt;/p&gt;&#xD;
&lt;p&gt;track_errors = Off&lt;br /&gt;; 是否在变量$php_errormsg中保存最近一个错误或警告消息。&lt;/p&gt;&#xD;
&lt;p&gt;display_errors = On&lt;br /&gt;; 是否将错误信息作为输出的一部分显示。&lt;br /&gt;; 在最终发布的web站点上，强烈建议你关掉这个特性，并使用错误日志代替(参看下面)。&lt;br /&gt;; 在最终发布的web站点打开这个特性可能暴露一些安全信息，&lt;br /&gt;; 例如你的web服务上的文件路径、数据库规划或别的信息。&lt;/p&gt;&#xD;
&lt;p&gt;display_startup_errors = Off&lt;br /&gt;; 是否显示PHP启动时的错误。&lt;br /&gt;; 即使display_errors指令被打开，关闭此参数也将不显示PHP启动时的错误。&lt;br /&gt;; 建议你关掉这个特性，除非你必须要用于调试中。&lt;/p&gt;&#xD;
&lt;p&gt;report_memleaks = On&lt;br /&gt;; 是否报告内存泄漏。这个参数只在以调试方式编译的PHP中起作用，&lt;br /&gt;; 并且必须在error_reporting指令中包含 E_WARNING&lt;/p&gt;&#xD;
&lt;p&gt;report_zend_debug = On&lt;br /&gt;; 尚无说明&lt;span &gt;文档&lt;/span&gt;&lt;/p&gt;&#xD;
&lt;p&gt;html_errors = On&lt;br /&gt;; 是否在出错信息中使用HTML标记。&lt;br /&gt;; 注意: 不要在发布的站点上使用这个特性！&lt;/p&gt;&#xD;
&lt;p&gt;docref_root =&amp;nbsp;&amp;nbsp;;"http://localhost/phpmanual/"&lt;br /&gt;docref_ext =&amp;nbsp; &amp;nbsp;;".html"&lt;br /&gt;; 如果打开了html_errors指令，PHP将会在出错信息上显示超连接，&lt;br /&gt;; 直接链接到一个说明这个错误或者导致这个错误的函数的页面。&lt;br /&gt;; 你可以从&lt;a href="http://www.php.net/docs.php" target="_blank"&gt;http://www.php.net/docs.php&lt;/a&gt;&lt;span &gt;下载&lt;/span&gt;php手册，&lt;br /&gt;; 并将docref_root指令指向你本地的手册所在的URL目录。&lt;br /&gt;; 你还必须设置docref_ext指令来指定文件的扩展名(必须含有'.')。&lt;br /&gt;; 注意: 不要在发布的站点上使用这个特性。&lt;/p&gt;&#xD;
&lt;p&gt;error_prepend_string =&amp;nbsp;&amp;nbsp;;"&amp;lt;font color="#000000"&amp;gt;"&lt;br /&gt;; 用于错误信息前输出的字符串&lt;br /&gt;error_append_string =&amp;nbsp; &amp;nbsp;;"&amp;lt;/font&amp;gt;"&lt;br /&gt;; 用于错误信息后输出的字符串&lt;/p&gt;&#xD;
&lt;p&gt;xmlrpc_errors = Off&lt;br /&gt;xmlrpc_error_number = 0&lt;br /&gt;; 尚无文档&lt;/p&gt;&#xD;
&lt;p&gt;&lt;br /&gt;[PHP-Core-Logging]&lt;/p&gt;&#xD;
&lt;p&gt;define_syslog_variables = Off&lt;br /&gt;; 是否定义各种系统日志变量，如：$LOG_PID, $LOG_CRON 等等。&lt;br /&gt;; 关掉它以提高效率的好主意。&lt;br /&gt;; 你可以在运行时调用define_syslog_variables()函数来定义这些变量。&lt;/p&gt;&#xD;
&lt;p&gt;error_log =&lt;br /&gt;; 将错误日志&lt;span &gt;记录&lt;/span&gt;到哪个文件中。该文件必须对Web服务器用户可写。&lt;br /&gt;; syslog 表示记录到系统日志中(NT下的事件日志, Unix下的syslog(3))&lt;br /&gt;; 如果此处未设置任何值，则错误将被记录到Web服务器的错误日志中。&lt;/p&gt;&#xD;
&lt;p&gt;log_errors = Off&lt;br /&gt;; 是否在日志文件里记录错误，具体在哪里记录取决于error_log指令。&lt;br /&gt;; 强烈建议你在最终发布的web站点时使用日志记录错误而不是直接输出，&lt;br /&gt;; 这样可以让你既知道那里出了问题，又不会暴露敏感信息。&lt;/p&gt;&#xD;
&lt;p&gt;log_errors_max_len = 1024&lt;br /&gt;; 设置错误日志中附加的与错误信息相关联的错误源的最大长度。&lt;br /&gt;; 这里设置的值对显示的和记录的错误以及$php_errormsg都有效。&lt;br /&gt;; 设为 0 可以允许无限长度。&lt;/p&gt;&#xD;
&lt;p&gt;ignore_repeated_errors = Off&lt;br /&gt;; 记录错误日志时是否忽略重复的错误信息。&lt;br /&gt;; 错误信息必须出现在同一文件的同一行才被被视为重复。&lt;/p&gt;&#xD;
&lt;p&gt;ignore_repeated_source = Off&lt;br /&gt;; 是否在忽略重复的错误信息时忽略重复的错误源。&lt;/p&gt;&#xD;
&lt;p&gt;&lt;br /&gt;[PHP-Core-Mail]&lt;br /&gt;; 要使邮件函数可用，PHP必须在编译时能够访问sendmail程序。&lt;br /&gt;; 如果使用其它的邮件程序，如qmail或postfix，确保使用了相应的sendmail包装。&lt;br /&gt;; PHP首先会在系统的PATH环境变量中搜索sendmail，接着按以下顺序搜索：&lt;br /&gt;; /usr/bin:/usr/sbin:/usr/etc:/etc:/usr/ucblib:/usr/lib&lt;br /&gt;; 强烈建议在PATH中能够找到sendmail。&lt;br /&gt;; 另外，编译PHP的用户必须能够访问sendmail程序。&lt;/p&gt;&#xD;
&lt;p&gt;SMTP = "localhost"&lt;br /&gt;; mail()函数中用来发送邮件的SMTP服务器的主机名称或者IP地址。仅用于win32。&lt;/p&gt;&#xD;
&lt;p&gt;smtp_port = 25&lt;br /&gt;; SMTP服务器的端口号。仅用于win32。&lt;/p&gt;&#xD;
&lt;p&gt;sendmail_from =&lt;br /&gt;; 发送邮件时使用的"From:"头中的邮件地址。仅用于win32&lt;br /&gt;; 该选项还同时设置了"Return-Path:"头。&lt;/p&gt;&#xD;
&lt;p&gt;sendmail_path = "-t -i"&lt;br /&gt;; 仅用于unix，也可支持参数(默认的是'sendmail -t -i')&lt;br /&gt;; sendmail程序的路径，通常为"/usr/sbin/sendmail或/usr/lib/sendmail"。&lt;br /&gt;; configure脚本会尝试找到该程序并设定为默认值，但是如果失败的话，可以在这里设定。&lt;br /&gt;; 不使用sendmail的系统应将此指令设定为sendmail替代程序(如果有的话)。&lt;br /&gt;; 例如，Qmail用户通常可以设为"/var/qmail/bin/sendmail"或"/var/qmail/bin/qmail-inject"。&lt;br /&gt;; qmail-inject 不需要任何选项就能正确处理邮件。&lt;/p&gt;&#xD;
&lt;p&gt;mail.force_extra_parameters =&lt;br /&gt;; 作为额外的参数传递给sendmail库的强制指定的参数附加值。&lt;br /&gt;; 这些参数总是会替换掉mail()的第5个参数，即使在安全模式下也是如此。&lt;/p&gt;&#xD;
&lt;p&gt;&lt;br /&gt;[PHP-Core-ResourceLimit]&lt;/p&gt;&#xD;
&lt;p&gt;default_socket_timeout = 60&lt;br /&gt;; 默认socket超时(秒)&lt;/p&gt;&#xD;
&lt;p&gt;max_execution_time = 30&lt;br /&gt;; 每个脚本最大允许执行时间(秒)，0 表示没有限制。&lt;br /&gt;; 这个参数有助于阻止劣质脚本无休止的占用服务器资源。&lt;br /&gt;; 该指令仅影响脚本本身的运行时间，任何其它花费在脚本运行之外的时间，&lt;br /&gt;; 如用system()/sleep()函数的使用、数据库&lt;span &gt;查询&lt;/span&gt;、文件上传等，都不包括在内。&lt;br /&gt;; 在安全模式下，你不能用ini_set()在运行时改变这个设置。&lt;/p&gt;&#xD;
&lt;p&gt;memory_limit = 128M&lt;br /&gt;; 一个脚本所能够申请到的最大内存字节数(可以使用K和M作为单位)。&lt;br /&gt;; 这有助于防止劣质脚本消耗完服务器上的所有内存。&lt;br /&gt;; 要能够使用该指令必须在编译时使用"--enable-memory-limit"配置选项。&lt;br /&gt;; 如果要取消内存限制，则必须将其设为 -1 。&lt;br /&gt;; 设置了该指令后，memory_get_usage()函数将变为可用。&lt;/p&gt;&#xD;
&lt;p&gt;max_input_time = -1&lt;br /&gt;; 每个脚本解析输入数据(POST, GET, upload)的最大允许时间(秒)。&lt;br /&gt;; -1 表示不限制。&lt;/p&gt;&#xD;
&lt;p&gt;max_input_nesting_level = 64&lt;br /&gt;; 输入变量的最大嵌套深度(尚无更多解释文档)&lt;/p&gt;&#xD;
&lt;p&gt;post_max_size = 8M&lt;br /&gt;; 允许的POST数据最大字节长度。此设定也影响到文件上传。&lt;br /&gt;; 如果POST数据超出限制，那么$_POST和$_FILES将会为空。&lt;br /&gt;; 要上传大文件，该值必须大于upload_max_filesize指令的值。&lt;br /&gt;; 如果启用了内存限制，那么该值应当小于memory_limit指令的值。&lt;/p&gt;&#xD;
&lt;p&gt;realpath_cache_size = 16K&lt;br /&gt;; 指定PHP使用的realpath(规范化的绝对路径名)缓冲区大小。&lt;br /&gt;; 在PHP打开大量文件的系统上应当增大该值以提高性能。&lt;/p&gt;&#xD;
&lt;p&gt;realpath_cache_ttl = 120&lt;br /&gt;; realpath缓冲区中信息的有效期(秒)。&lt;br /&gt;; 对文件很少变动的系统，可以增大该值以提高性能。&lt;/p&gt;&#xD;
&lt;p&gt;&lt;br /&gt;[PHP-Core-FileUpLoad]&lt;/p&gt;&#xD;
&lt;p&gt;file_uploads = On&lt;br /&gt;; 是否允许HTTP文件上传。&lt;br /&gt;; 参见upload_max_filesize, upload_tmp_dir, post_max_size指令&lt;/p&gt;&#xD;
&lt;p&gt;upload_max_filesize = 2M&lt;br /&gt;; 允许上传的文件的最大尺寸。&lt;/p&gt;&#xD;
&lt;p&gt;upload_tmp_dir =&lt;br /&gt;; 文件上传时存放文件的临时目录(必须是PHP进程用户可写的目录)。&lt;br /&gt;; 如果未指定则PHP使用系统默认的临时目录。&lt;/p&gt;&#xD;
&lt;p&gt;&lt;br /&gt;[PHP-Core-MagicQuotes]&lt;br /&gt;; PHP6删除了下列指令，相当于全部为 Off&lt;/p&gt;&#xD;
&lt;p&gt;magic_quotes_gpc = Off&lt;br /&gt;; 是否对输入的GET/POST/Cookie数据使用自动字符串转义( '&amp;nbsp;&amp;nbsp;"&amp;nbsp;&amp;nbsp;\&amp;nbsp;&amp;nbsp;NULL )。&lt;br /&gt;; 这里的设置将自动影响 $_GEST $_POST $_COOKIE 数组的值。&lt;br /&gt;; 若将本指令与magic_quotes_sybase指令同时打开，则仅将单引号(')转义为('')，&lt;br /&gt;; 其它特殊字符将不被转义，即( "&amp;nbsp;&amp;nbsp;\&amp;nbsp;&amp;nbsp;NULL )将保持原样！！&lt;br /&gt;; 建议关闭此特性，并使用自定义的过滤函数。&lt;/p&gt;&#xD;
&lt;p&gt;magic_quotes_runtime = Off&lt;br /&gt;; 是否对运行时从外部资源产生的数据使用自动字符串转义( '&amp;nbsp;&amp;nbsp;"&amp;nbsp;&amp;nbsp;\&amp;nbsp;&amp;nbsp;NULL )。&lt;br /&gt;; 若打开本指令，则大多数函数从外部资源(数据库,文本文件等)返回数据都将被转义。&lt;br /&gt;; 例如：用SQL查询得到的数据，用exec()函数得到的数据，等等&lt;br /&gt;; 若将本指令与magic_quotes_sybase指令同时打开，则仅将单引号(')转义为('')，&lt;br /&gt;; 其它特殊字符将不被转义，即( "&amp;nbsp;&amp;nbsp;\&amp;nbsp;&amp;nbsp;NULL )将保持原样！！&lt;br /&gt;; 建议关闭此特性，并视具体情况使用自定义的过滤函数。&lt;/p&gt;&#xD;
&lt;p&gt;magic_quotes_sybase = Off&lt;br /&gt;; 是否采用Sybase形式的自动字符串转义(用 '' 表示 ')&lt;/p&gt;&#xD;
&lt;p&gt;&lt;br /&gt;[PHP-Core-HighLight]&lt;/p&gt;&#xD;
&lt;p&gt;highlight.bg = "#FFFFFF"&lt;br /&gt;highlight.comment = "#FF8000"&lt;br /&gt;highlight.default = "#0000BB"&lt;br /&gt;highlight.html = "#000000"&lt;br /&gt;highlight.keyword = "#007700"&lt;br /&gt;highlight.string = "#DD0000"&lt;br /&gt;; 语法高亮模式的色彩(通常用于显示 .phps 文件)。&lt;br /&gt;; 只要能被&amp;lt;font color=xxx&amp;gt;接受的东西就能正常工作。&lt;/p&gt;&#xD;
&lt;p&gt;&lt;br /&gt;[PHP-Core-Langue]&lt;/p&gt;&#xD;
&lt;p&gt;short_open_tag = On&lt;br /&gt;; 是否允许使用"&amp;lt;? ?&amp;gt;"短标识。否则必须使用"&amp;lt;?php ?&amp;gt;"长标识。&lt;br /&gt;; 除非你的php程序仅在受控环境下运行，且只供自己使用，否则请不要使用短标记。&lt;br /&gt;; 如果要和XML结合使用PHP，可以选择关闭此选项以方便直接嵌入"&amp;lt;?xml ... ?&amp;gt;"，&lt;br /&gt;; 不然你必须用PHP来输出：&amp;lt;? echo '&amp;lt;?xml version="1.0"'; ?&amp;gt;&lt;br /&gt;; 本指令也会影响到缩写形式"&amp;lt;?="，它和"&amp;lt;? echo"等价，要使用它也必须打开短标记。&lt;/p&gt;&#xD;
&lt;p&gt;asp_tags = Off&lt;br /&gt;; 是否允许ASP风格的标记"&amp;lt;% %&amp;gt;"，这也会影响到缩写形式"&amp;lt;%="。&lt;br /&gt;; PHP6中将删除此指令&lt;/p&gt;&#xD;
&lt;p&gt;arg_separator.output = "&amp;amp;"&lt;br /&gt;; PHP所产生的URL中用来分隔参数的分隔符。&lt;br /&gt;; 另外还可以用"&amp;amp;"或","等等。&lt;/p&gt;&#xD;
&lt;p&gt;arg_separator.input = "&amp;amp;"&lt;br /&gt;; PHP解析URL中的变量时使用的分隔符列表。&lt;br /&gt;; 字符串中的每一个字符都会被当作分割符。&lt;br /&gt;; 另外还可以用",&amp;amp;"等等。&lt;/p&gt;&#xD;
&lt;p&gt;allow_call_time_pass_reference = On&lt;br /&gt;; 是否强迫在函数调用时按引用传递参数(每次使用此特性都会收到一条警告)。&lt;br /&gt;; php反对这种做法，并在PHP6里删除了该指令(相当于设为Off)，因为它影响到了&lt;span &gt;代码&lt;/span&gt;的整洁。&lt;br /&gt;; 鼓励的方法是在函数声明里明确指定哪些参数按引用传递。&lt;br /&gt;; 我们鼓励你关闭这一选项，以保证你的脚本在将来版本的&lt;span &gt;语言&lt;/span&gt;里仍能正常工作。&lt;/p&gt;&#xD;
&lt;p&gt;auto_globals_jit = On&lt;br /&gt;; 是否仅在使用到$_SERVER和$_ENV变量时才创建(而不是在脚本一启动时就自动创建)。&lt;br /&gt;; 如果并未在脚本中使用这两个数组，打开该指令将会获得性能上的提升。&lt;br /&gt;; 要想该指令生效，必须关闭register_globals和register_long_arrays指令。&lt;/p&gt;&#xD;
&lt;p&gt;auto_prepend_file =&lt;br /&gt;auto_append_file&amp;nbsp;&amp;nbsp;=&lt;br /&gt;; 指定在主文件之前/后自动解析的文件名。为空表示禁用该特性。&lt;br /&gt;; 该文件就像调用了include()函数被包含进来一样，因此会使用include_path指令的值。&lt;br /&gt;; 注意：如果脚本通过exit()终止，那么自动后缀将不会发生。&lt;/p&gt;&#xD;
&lt;p&gt;variables_order = "EGPCS"&lt;br /&gt;; PHP注册 Environment, GET, POST, Cookie, Server 变量的顺序。&lt;br /&gt;; 分别用 E, G, P, C, S 表示，按从左到右注册，新值覆盖旧值。&lt;br /&gt;; 举例说，设为"GP"将会导致用POST变量覆盖同名的GET变量，&lt;br /&gt;; 并完全忽略 Environment, Cookie, Server 变量。&lt;br /&gt;; 推荐使用"GPC"或"GPCS"，并使用getenv()函数访问环境变量。&lt;/p&gt;&#xD;
&lt;p&gt;register_globals = Off&lt;br /&gt;; 是否将 E, G, P, C, S 变量注册为全局变量。&lt;br /&gt;; 打开该指令可能会导致严重的安全问题，除非你的脚本经过非常仔细的检查。&lt;br /&gt;; 推荐使用预定义的超全局变量：$_ENV, $_GET, $_POST, $_COOKIE, $_SERVER&lt;br /&gt;; 该指令受variables_order指令的影响。&lt;br /&gt;; PHP6中已经删除此指令。&lt;/p&gt;&#xD;
&lt;p&gt;register_argc_argv = On&lt;br /&gt;; 是否声明$argv和$argc全局变量(包含用GET方法的信息)。&lt;br /&gt;; 建议不要使用这两个变量，并关掉该指令以提高性能。&lt;/p&gt;&#xD;
&lt;p&gt;register_long_arrays = On&lt;br /&gt;; 是否启用旧式的长式数组(HTTP_*_VARS)。&lt;br /&gt;; 鼓励使用短式的预定义超全局数组，并关闭该特性以获得更好的性能。&lt;br /&gt;; PHP6中已经删除此指令。&lt;/p&gt;&#xD;
&lt;p&gt;always_populate_raw_post_data = Off&lt;br /&gt;; 是否总是生成$HTTP_RAW_POST_DATA变量(原始POST数据)。&lt;br /&gt;; 否则，此变量仅在遇到不能识别的MIME类型的数据时才产生。&lt;br /&gt;; 不过，访问原始POST数据的更好方法是 php://input 。&lt;br /&gt;; $HTTP_RAW_POST_DATA对于enctype="multipart/form-data"的&lt;span &gt;表单&lt;/span&gt;数据不可用。&lt;/p&gt;&#xD;
&lt;p&gt;unserialize_callback_func =&lt;br /&gt;; 如果解序列化处理器需要&lt;span &gt;实例&lt;/span&gt;化一个未定义的类，&lt;br /&gt;; 这里指定的回调函数将以该未定义类的名字作为参数被unserialize()调用，&lt;br /&gt;; 以免得到不完整的"__PHP_Incomplete_Class"&lt;span &gt;对象&lt;/span&gt;。&lt;br /&gt;; 如果这里没有指定函数，或指定的函数不包含(或实现)那个未定义的类，将会显示警告信息。&lt;br /&gt;; 所以仅在确实需要实现这样的回调函数时才设置该指令。&lt;br /&gt;; 若要禁止这个特性，只需置空即可。&lt;/p&gt;&#xD;
&lt;p&gt;y2k_compliance = On&lt;br /&gt;; 是否强制打开2000年适应(可能在非Y2K适应的浏览器中导致问题)。&lt;/p&gt;&#xD;
&lt;p&gt;zend.ze1_compatibility_mode = Off&lt;br /&gt;; 是否使用兼容Zend引擎I(PHP 4.x)的模式。PHP6中将删除该指令(相当于Off)。&lt;br /&gt;; 这将影响对象的复制、构造(无&lt;span &gt;属性&lt;/span&gt;的对象会产生FALSE或0)、比较。&lt;br /&gt;; 兼容模式下，对象将按值传递，而不是默认的按引用传递。&lt;/p&gt;&#xD;
&lt;p&gt;precision = 14&lt;br /&gt;; 浮点型数据显示的有效位数。&lt;/p&gt;&#xD;
&lt;p&gt;serialize_precision = 100&lt;br /&gt;; 将浮点型和双精度型数据序列化存储时的精度(有效位数)。&lt;br /&gt;; 默认值能够确保浮点型数据被解序列化程序解码时不会丢失数据。&lt;/p&gt;&#xD;
&lt;p&gt;&lt;br /&gt;[PHP-Core-OutputControl]&lt;br /&gt;; 输出控制函数很有用，特别是在已经输出了信息之后再发送HTTP头的情况下。&lt;br /&gt;; 输出控制函数不会作用于header()或setcookie()等函数发送的HTTP头，&lt;br /&gt;; 而只会影响类似于echo()函数输出的信息和嵌入在PHP代码之间的信息。&lt;/p&gt;&#xD;
&lt;p&gt;implicit_flush = Off&lt;br /&gt;; 是否要求PHP输出层在每个输出块之后自动刷新数据。&lt;br /&gt;; 这等效于在每个 print()、echo()、HTML块 之后自动调用flush()函数。&lt;br /&gt;; 打开这个选项对程序执行的性能有严重的影响，通常只推荐在调试时使用。&lt;br /&gt;; 在CLI S&lt;span &gt;API&lt;/span&gt;的执行模式下，该指令默认为 On 。&lt;/p&gt;&#xD;
&lt;p&gt;output_buffering = 0&lt;br /&gt;; 输出缓冲区大小(字节)。建议值为4096~8192。&lt;br /&gt;; 输出缓冲允许你甚至在输出正文内容之后再发送HTTP头(包括cookies)。&lt;br /&gt;; 其代价是输出层减慢一点点速度。&lt;br /&gt;; 设置输出缓冲可以减少写入，有时还能减少网络数据包的发送。&lt;br /&gt;; 这个参数的实际收益很大程度上取决于你使用的是什么Web服务器以及什么样的脚本。&lt;/p&gt;&#xD;
&lt;p&gt;output_handler =&lt;br /&gt;; 将所有脚本的输出重定向到一个输出处理函数。&lt;br /&gt;; 比如，重定向到mb_output_handler()函数时，字符编码将被透明地转换为指定的编码。&lt;br /&gt;; 一旦你在这里指定了输出处理程序，输出缓冲将被自动打开(output_buffering=4096)。&lt;br /&gt;; 注意0: 此处仅能使用PHP内置的函数，自定义函数应在脚本中使用ob_start()指定。&lt;br /&gt;; 注意1: 可移植脚本不能依赖该指令，而应使用ob_start()函数明确指定输出处理函数。&lt;br /&gt;;&amp;nbsp; &amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp;使用这个指令可能会导致某些你不熟悉的脚本出错。&lt;br /&gt;; 注意2: 你不能同时使用"mb_output_handler"和"ob_iconv_handler"两个输出处理函数。&lt;br /&gt;;&amp;nbsp; &amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp;你也不能同时使用"ob_gzhandler"输出处理函数和zlib.output_compression指令。&lt;br /&gt;; 注意3: 如果使用zlib.output_handler指令开启zlib输出压缩，该指令必须为空。&lt;/p&gt;&#xD;
&lt;p&gt;&lt;br /&gt;[PHP-Core-Directory]&lt;/p&gt;&#xD;
&lt;p&gt;include_path = ".:/path/to/php/pear"&lt;br /&gt;; 指定一组目录用于require(), include(), fopen_with_path()函数寻找文件。&lt;br /&gt;; 格式和系统的PATH环境变量类似(UNIX下用冒号分隔，Windows下用分号分隔)：&lt;br /&gt;; UNIX: "/path1:/path2"&lt;br /&gt;; Windows: "\path1;\path2"&lt;br /&gt;; 在包含路径中使用'.'可以允许相对路径，它代表当前目录。&lt;/p&gt;&#xD;
&lt;p&gt;user_dir =&lt;br /&gt;; 告诉php在使用 /~username 打开脚本时到哪个目录下去找，仅在非空时有效。&lt;br /&gt;; 也就是在用户目录之下使用PHP文件的基本目录名，例如："public_html"&lt;/p&gt;&#xD;
&lt;p&gt;extension_dir = "/path/to/php"&lt;br /&gt;; 存放扩展库(模块)的目录，也就是PHP用来寻找动态扩展模块的目录。&lt;br /&gt;; Windows下默认为"C:/php5"&lt;/p&gt;&#xD;
&lt;p&gt;&lt;br /&gt;[PHP-Core-HTTP]&lt;/p&gt;&#xD;
&lt;p&gt;default_mimetype = "text/html"&lt;br /&gt;default_charset =&amp;nbsp;&amp;nbsp;;"gb2312"&lt;br /&gt;; PHP默认会自动输出"Content-Type: text/html" HTTP头。&lt;br /&gt;; 如果将default_charset指令设为"gb2312"，&lt;br /&gt;; 那么将会自动输出"Content-Type: text/html; charset=gb2312"。&lt;br /&gt;; PHP6反对使用default_charset指令，而推荐使用unicode.output_encoding指令。&lt;/p&gt;&#xD;
&lt;p&gt;&lt;br /&gt;[PHP-Core-Unicode]&lt;br /&gt;; PHP6基于ICU(International Components for Unicode)库提供了全面的Unicode支持。&lt;br /&gt;; 编译时需要使用--with-icu-dir=&amp;lt;dir&amp;gt;指定ICU头文件和库的安装位置。&lt;br /&gt;; 除detect_unicode外，其他都是PHP6新增的指令。&lt;br /&gt;;&lt;br /&gt;; PHP6的信息目前还很缺乏，所以此部分内容可能不完整甚至有错误。&lt;/p&gt;&#xD;
&lt;p&gt;detect_unicode = On&lt;br /&gt;; 指示Zend引擎是否通过检查脚本的BOM(字节顺序标记)来检测脚本是否包含多字节字符。&lt;br /&gt;; 建议关闭。PHP6已经取消了此指令而用unicode.script_encoding指令来代替其&lt;span &gt;功能&lt;/span&gt;。&lt;/p&gt;&#xD;
&lt;p&gt;unicode.semantics = Off&lt;br /&gt;; 是否启用Unicode支持。&lt;br /&gt;; 如果打开此指令，那么PHP将变成一个完全的Unicode环境，比如：&lt;br /&gt;; 所有字符串和从HTTP接受的变量都将变成Unicode，所有PHP标识符也都可以使用Unicode字符。&lt;br /&gt;; 而且，PHP内部将使用Unicode字符串并负责对外围非Unicode字符进行自动转换，&lt;br /&gt;; 比如：HTTP输入输出、流、文件系统操作等等，甚至连php.ini自身都将按照UTF-8编码来解析。&lt;br /&gt;; 开启这个指令后，你必须明确指定二进制字符串。PHP将不对二进制字符串的内容做任何假定，&lt;br /&gt;; 因此你的程序必须保证能够恰当的处理二进制字符串。&lt;br /&gt;; 如果关闭这个指令，PHP的行为将和以前的行为完全相同：&lt;br /&gt;; 字符串不会变成Unicode，文件和二进制字符串也将向后兼容，php.ini也将按照"as-is"风格解析。&lt;br /&gt;; 不管是否打开此指令，所有的函数和操作符都透明的支持Unicode字符串。&lt;/p&gt;&#xD;
&lt;p&gt;unicode.fallback_encoding = UTF-8&lt;br /&gt;; 为其他所有unicode.*_encoding指令设置默认值。&lt;br /&gt;; 也就是说如果某个unicode.*_encoding指令未明确设置的话，将使用此处设置的值。&lt;/p&gt;&#xD;
&lt;p&gt;unicode.runtime_encoding =&lt;br /&gt;; 运行时编码指定了PHP引擎内部转换二进制字符串时使用的编码。&lt;br /&gt;; 此处的设置对于I/O相关操作(比如：写入标准输出/读取文件系统/解码HTTP输入变量)没有影响。&lt;br /&gt;; PHP也允许你明确的对字符串进行转换：&lt;br /&gt;; (binary)$str&amp;nbsp;&amp;nbsp;-- 转化为二进制字符串&lt;br /&gt;; (unicode)$str -- 转化为Unicode字符串&lt;br /&gt;; (string)$str&amp;nbsp;&amp;nbsp;-- 如果unicode.semantics为On则转化为Unicode字符串，否则转化为二进制字符串&lt;br /&gt;; 例如，如果该指令的值为iso-8859-1并且$uni是一个Unicode字符串，那么&lt;br /&gt;; $str = (binary)$uni&lt;br /&gt;; 将等到一个使用iso-8859-1编码的二进制字符串。&lt;br /&gt;; 在连接、比较、传递参数等操作之前PHP会将相关字符串隐含转换为Unicode，然后再进行操作。&lt;br /&gt;; 比如在将二进制字符串与Unicode进行连接的时候，&lt;br /&gt;; PHP将会使用这里的设置将二进制字符串转换为Unicode字符串，然后再进行操作。&lt;/p&gt;&#xD;
&lt;p&gt;unicode.output_encoding =&lt;br /&gt;; PHP输出非二进制字符串使用的编码。&lt;br /&gt;; 自动将'print'和'echo'之类的输出内容转换为此处设定的编码(并不对二进制字符串进行转换)。&lt;br /&gt;; 当向文件之类的外部资源写入数据的时候，&lt;br /&gt;; 你必须依赖于流编码特性或者使用Unicode扩展的函数手动的对数据进行编码。&lt;br /&gt;; 在PHP6中反对使用先前的default_charset指令，而推荐使用该指令。&lt;br /&gt;; 先前的default_charset指令只是指定了Content-Type头中的字符集，而并不对实际的输出做任何转换。&lt;br /&gt;; 而在PHP6中，default_charset指令仅在unicode.semantics为off的时候才有效。&lt;br /&gt;; 设置了该指令后将在Content-Type输出头的'charset'部分填上该指令的值，&lt;br /&gt;; 而不管default_charset指令如何设置。&lt;/p&gt;&#xD;
&lt;p&gt;unicode.http_input_encoding =&lt;br /&gt;; 通过HTTP获取的变量(比如$_GET和_$POST)内容的编码。&lt;br /&gt;; 直到2007年4月此功能尚在&lt;span &gt;开发&lt;/span&gt;中....&lt;/p&gt;&#xD;
&lt;p&gt;unicode.filesystem_encoding =&lt;br /&gt;; 文件系统的目录名和文件名的编码。&lt;br /&gt;; 文件系统相关的函数(比如opendir())将使用这个编码接受和返回文件名和目录名。&lt;br /&gt;; 此处的设置必须与文件系统实际使用的编码完全一致。&lt;/p&gt;&#xD;
&lt;p&gt;unicode.script_encoding =&lt;br /&gt;; PHP脚本自身的默认编码。&lt;br /&gt;; 你可以使用任何ICU支持的编码来写PHP脚本。&lt;br /&gt;; 如果你想针对单独的脚本文件设定其编码，可以在该脚本的开头使用&lt;br /&gt;;&amp;nbsp; &amp;nbsp;&amp;lt;?php declare(encoding = 'Shift-JIS'); ?&amp;gt;&lt;br /&gt;; 来指定。注意：必须是第一行开头，全面不要有任何字符(包括空白)。&lt;br /&gt;; 该方法只能影响其所在的脚本，不会影响任何被包含的其他脚本。&lt;/p&gt;&#xD;
&lt;p&gt;unicode.stream_encoding&amp;nbsp; &amp;nbsp; = UTF-8&lt;br /&gt;unicode.from_error_mode = 2&lt;br /&gt;unicode.from_error_subst_char = 3f&lt;br /&gt;; 尚无文档&lt;/p&gt;&#xD;
&lt;p&gt;&lt;br /&gt;[PHP-Core-Misc]&lt;/p&gt;&#xD;
&lt;p&gt;auto_detect_line_endings = Off&lt;br /&gt;; 是否让PHP自动侦测行结束符(EOL)。&lt;br /&gt;; 如果的你脚本必须处理Macintosh文件，&lt;br /&gt;; 或者你运行在Macintosh上，同时又要处理unix或win32文件，&lt;br /&gt;; 打开这个指令可以让PHP自动侦测EOL，以便fgets()和file()函数可以正常工作。&lt;br /&gt;; 但同时也会导致在Unix系统下使用回车符(CR)作为项目分隔符的人遭遇不兼容行为。&lt;br /&gt;; 另外，在检测第一行的EOL习惯时会有很小的性能损失。&lt;/p&gt;&#xD;
&lt;p&gt;browscap =&amp;nbsp;&amp;nbsp;;"c:/windows/system32/inetsrv/browscap.ini"&lt;br /&gt;; 只有PWS和IIS需要这个设置&lt;br /&gt;; 你可以从&lt;a href="http://www.garykeith.com/browsers/downloads.asp" target="_blank"&gt;http://www.garykeith.com/browsers/downloads.asp&lt;/a&gt;&lt;br /&gt;; 得到一个browscap.ini文件。&lt;/p&gt;&#xD;
&lt;p&gt;ignore_user_abort = Off&lt;br /&gt;; 是否即使在用户中止请求后也坚持完成整个请求。&lt;br /&gt;; 在执行一个长请求的时候应当考虑打开该它，&lt;br /&gt;; 因为长请求可能会导致用户中途中止或浏览器超时。&lt;/p&gt;&#xD;
&lt;p&gt;user_agent =&amp;nbsp;&amp;nbsp;;"&lt;img src="http://qeephp.com/bbs/images/smilies/default/titter.gif" border="0" alt="" /&gt;HP"&lt;br /&gt;; 定义"User-Agent"字符串&lt;/p&gt;&#xD;
&lt;p&gt;;url_rewriter.tags = "a=href,area=href,frame=src,form=,fieldset="&lt;br /&gt;; 虽然此指令属于PHP核心部分，但是却用于Session模块的配置&lt;/p&gt;&#xD;
&lt;p&gt;;extension =&lt;br /&gt;; 在PHP启动时加载动态扩展。例如：extension=mysqli.so&lt;br /&gt;; "="之后只能使用模块文件的名字，而不能含有路径信息。&lt;br /&gt;; 路径信息应当只由extension_dir指令提供。&lt;br /&gt;; 主意，在windows上，下列扩展已经内置：&lt;br /&gt;; bcmath ; calendar ; com_dotnet ; ctype ; &lt;span &gt;session&lt;/span&gt; ; filter ; ftp ; hash&lt;br /&gt;; iconv ; json ; odbc ; pcre ; Reflection ; date ; libxml ; standard&lt;br /&gt;; tokenizer ; zlib ; SimpleXML ; dom ; SPL ; wddx ; xml ; xmlreader ; xmlwriter&lt;/p&gt;&#xD;
&lt;p&gt;&lt;br /&gt;[PHP-Core-CGI]&lt;br /&gt;; 这些指令只有在将PHP运行在CGI模式下的时候才有效&lt;/p&gt;&#xD;
&lt;p&gt;doc_root =&lt;br /&gt;; PHP的"CGI根目录"。仅在非空时有效。&lt;br /&gt;; 在web服务器的主文档目录(比如"htdocs")中放置可执行程序/脚本被认为是不安全的，&lt;br /&gt;; 比如因为配置错误而将脚本作为普通的html显示。&lt;br /&gt;; 因此很多系统管理员都会在主文档目录之外专门设置一个只能通过CGI来访问的目录，&lt;br /&gt;; 该目录中的内容只会被解析而不会原样显示出来。&lt;br /&gt;; 如果设置了该项，那么PHP就只会解释doc_root目录下的文件，&lt;br /&gt;; 并确保目录外的脚本都不会被PHP解释器执行(user_dir除外)。&lt;br /&gt;; 如果编译PHP时没有指定FORCE_REDIRECT，并且在非IIS服务器上以CGI方式运行，&lt;br /&gt;; 则必须设置此指令(参见手册中的安全部分)。&lt;br /&gt;; 替代方案是使用的cgi.force_redirect指令。&lt;/p&gt;&#xD;
&lt;p&gt;cgi.discard_path = Off&lt;br /&gt;; 尚无文档(PHP6新增指令)&lt;/p&gt;&#xD;
&lt;p&gt;cgi.fix_pathinfo = On&lt;br /&gt;; 是否为CGI提供真正的 PATH_INFO/PATH_TRANSLATED 支持(遵守cgi规范)。&lt;br /&gt;; 先前的行为是将PATH_TRANSLATED设为SCRIPT_FILENAME，而不管PATH_INFO是什么。&lt;br /&gt;; 打开此选项将使PHP修正其路径以遵守CGI规范，否则仍将使用旧式的不合规范的行为。&lt;br /&gt;; 鼓励你打开此指令，并修正脚本以使用 SCRIPT_FILENAME 代替 PATH_TRANSLATED 。&lt;br /&gt;; 有关PATH_INFO的更多信息请参见cgi规范。&lt;/p&gt;&#xD;
&lt;p&gt;cgi.force_redirect = On&lt;br /&gt;; 是否打开cgi强制重定向。强烈建议打开它以为CGI方式运行的php提供安全保护。&lt;br /&gt;; 你若自己关闭了它，请自己负责后果。&lt;br /&gt;; 注意：在IIS/OmniHTTPD/Xitami上则必须关闭它！&lt;/p&gt;&#xD;
&lt;p&gt;cgi.redirect_status_env =&lt;br /&gt;; 如果cgi.force_redirect=On，并且在Apache与Netscape之外的服务器下运行PHP，&lt;br /&gt;; 可能需要设定一个cgi重定向环境变量名，PHP将去寻找它来知道是否可以继续执行下去。&lt;br /&gt;; 设置这个变量会导致安全漏洞，请务必在设置前搞清楚自己在做什么。&lt;/p&gt;&#xD;
&lt;p&gt;cgi.rfc2616_headers = 0&lt;br /&gt;; 指定PHP在发送HTTP响应代码时使用何种报头。&lt;br /&gt;; 0 表示发送一个"Status: "报头，Apache和其它web服务器都支持。&lt;br /&gt;; 若设为1，则PHP使用RFC2616标准的头。&lt;br /&gt;; 除非你知道自己在做什么，否则保持其默认值 0&lt;/p&gt;&#xD;
&lt;p&gt;cgi.nph = Off&lt;br /&gt;; 在CGI模式下是否强制对所有请求都发送"Status: 200"状态码。&lt;/p&gt;&#xD;
&lt;p&gt;cgi.check_shebang_line =On&lt;br /&gt;; CGI PHP是否检查脚本顶部以 #! 开始的行。&lt;br /&gt;; 如果脚本想要既能够单独运行又能够在PHP CGI模式下运行，那么这个起始行就是必须的。&lt;br /&gt;; 如果打开该指令，那么CGI模式的PHP将跳过这一行。&lt;/p&gt;&#xD;
&lt;p&gt;fastcgi.impersonate = Off&lt;br /&gt;; IIS中的FastCGI支持模仿客户端安全令牌的能力。&lt;br /&gt;; 这使得IIS能够定义运行时所基于的请求的安全上下文。&lt;br /&gt;; Apache中的mod_fastcgi不支持此特性(03/17/2002)&lt;br /&gt;; 如果在IIS中运行则设为On，默认为Off。&lt;/p&gt;&#xD;
&lt;p&gt;fastcgi.logging = On&lt;br /&gt;; 是否记录通过FastCGI进行的连接。&lt;/p&gt;&#xD;
&lt;p&gt;&lt;br /&gt;[PHP-Core-Weirdy]&lt;br /&gt;; 这些选项仅存在于文档中，却不存在于phpinfo()函数的输出中&lt;/p&gt;&#xD;
&lt;p&gt;async_send = Off&lt;br /&gt;; 是否异步发送。&lt;/p&gt;&#xD;
&lt;p&gt;from =&amp;nbsp;&amp;nbsp;;"john@doe.com"&lt;br /&gt;; 定义匿名ftp的&lt;span &gt;密码&lt;/span&gt;(一个email地址)&lt;/p&gt;&#xD;
&lt;p&gt;&lt;br /&gt;;;;;;;;;;;;;;;;;;;&lt;br /&gt;;;&amp;nbsp;&amp;nbsp;近核心模块&amp;nbsp;&amp;nbsp;;;&lt;br /&gt;;;;;;;;;;;;;;;;;;;&lt;/p&gt;&#xD;
&lt;p&gt;[Pcre]&lt;br /&gt;;Perl兼容正则表达式模块&lt;/p&gt;&#xD;
&lt;p&gt;pcre.backtrack_limit = 100000&lt;br /&gt;; PCRE的最大回溯(backtracking)步数。&lt;/p&gt;&#xD;
&lt;p&gt;pcre.recursion_limit = 100000&lt;br /&gt;; PCRE的最大递归(recursion)深度。&lt;br /&gt;; 如果你将该值设的非常高，将可能耗尽进程的栈空间，导致PHP崩溃。&lt;/p&gt;&#xD;
&lt;p&gt;&lt;br /&gt;[Session]&lt;br /&gt;; 除非使用session_register()或$_SESSION注册了一个变量。&lt;br /&gt;; 否则不管是否使用了session_start()，都不会自动添加任何session记录。&lt;br /&gt;; 包括resource变量或有循环引用的对象包含指向自身的引用的对象，不能保存在会话中。&lt;br /&gt;; register_globals指令会影响到会话变量的存储和恢复。&lt;/p&gt;&#xD;
&lt;p&gt;session.save_handler = "files"&lt;br /&gt;; 存储和检索与会话关联的数据的处理器名字。默认为文件("files")。&lt;br /&gt;; 如果想要使用自定义的处理器(如基于数据库的处理器)，可用"user"。&lt;br /&gt;; 设为"memcache"则可以使用memcache作为会话处理器(需要指定"--enable-memcache-session"编译选项)。&lt;br /&gt;; 还有一个使用PostgreSQL的处理器：&lt;a href="http://sourceforge.net/projects/phpform-ext/" target="_blank"&gt;http://sourceforge.net/projects/phpform-ext/&lt;/a&gt;&lt;/p&gt;&#xD;
&lt;p&gt;session.save_path = "/tmp"&lt;br /&gt;; 传递给存储处理器的参数。对于files处理器，此值是创建会话数据文件的路径。&lt;br /&gt;; Windows下默认为临时文件夹路径。&lt;br /&gt;; 你可以使用"N;[MODE;]/path"这样模式定义该路径(N是一个整数)。&lt;br /&gt;; N表示使用N层深度的子目录，而不是将所有数据文件都保存在一个目录下。&lt;br /&gt;; [MODE;]可选，必须使用8进制数，默认"600"，表示文件的访问&lt;span &gt;权限&lt;/span&gt;。&lt;br /&gt;; 这是一个提高大量会话性能的好主意。&lt;br /&gt;; 注意0: "N;[MODE;]/path"两边的双引号不能省略。&lt;br /&gt;; 注意1: [MODE;]并不会改写进程的umask。&lt;br /&gt;; 注意2: php不会自动创建这些文件夹结构。请使用ext/session目录下的mod_files.sh脚本创建。&lt;br /&gt;; 注意3: 如果该文件夹可以被不安全的用户访问(比如默认的"/tmp")，那么将会带来安全漏洞。&lt;br /&gt;; 注意4: 当N&amp;gt;0时自动垃圾回收将会失效，具体参见下面有关垃圾搜集的部分。&lt;br /&gt;; [安全提示]建议针对每个不同的虚拟主机分别设置各自不同的目录。&lt;br /&gt;;&lt;br /&gt;; 对于"memcache"处理器，需要定义一个逗号分隔的服务器URL用来存储会话数据。&lt;br /&gt;; 比如："tcp://host1:11211, tcp://host2:11211"&lt;br /&gt;; 每个URL都可以包含传递给那个服务器的参数，可用的参数与 Memcache::addServer() 方法相同。&lt;br /&gt;; 例如："tcp://host1:11211?persistent=1&amp;amp;weight=1&amp;amp;timeout=1&amp;amp;retry_interval=15"&lt;/p&gt;&#xD;
&lt;p&gt;session.name = "PHPSESSID"&lt;br /&gt;;用在cookie里的会话ID标识名，只能包含字母和数字。&lt;/p&gt;&#xD;
&lt;p&gt;session.auto_start = Off&lt;br /&gt;; 在客户访问任何页面时都自动初始化会话，默认禁止。&lt;br /&gt;; 因为类定义必须在会话启动之前被载入，所以若打开这个选项，你就不能在会话中存放对象。&lt;/p&gt;&#xD;
&lt;p&gt;session.serialize_handler = "php"&lt;br /&gt;; 用来序列化/解序列化数据的处理器，php是标准序列化/解序列化处理器。&lt;br /&gt;; 另外还可以使用"php_binary"。当启用了WDDX支持以后，将只能使用"wddx"。&lt;/p&gt;&#xD;
&lt;p&gt;session.gc_probability = 1&lt;br /&gt;session.gc_divisor = 100&lt;br /&gt;; 定义在每次初始化会话时，启动垃圾回收程序的概率。&lt;br /&gt;; 这个收集概率计算公式如下：session.gc_probability/session.gc_divisor&lt;br /&gt;; 对会话页面访问越频繁，概率就应当越小。建议值为1/1000~5000。&lt;/p&gt;&#xD;
&lt;p&gt;session.gc_maxlifetime = 1440&lt;br /&gt;; 超过此参数所指的秒数后，保存的数据将被视为'垃圾'并由垃圾回收程序清理。&lt;br /&gt;; 判断标准是最后访问数据的时间(对于FAT文件系统是最后刷新数据的时间)。&lt;br /&gt;; 如果多个脚本共享同一个session.save_path目录但session.gc_maxlifetime不同，&lt;br /&gt;; 那么将以所有session.gc_maxlifetime指令中的最小值为准。&lt;br /&gt;; 如果使用多层子目录来存储数据文件，垃圾回收程序不会自动启动。&lt;br /&gt;; 你必须使用一个你自己编写的shell脚本、cron项或者其他办法来执行垃圾搜集。&lt;br /&gt;; 比如，下面的脚本相当于设置了"session.gc_maxlifetime=1440" (24分钟)：&lt;br /&gt;; cd /path/to/sessions; find -cmin +24 | xargs rm&lt;/p&gt;&#xD;
&lt;p&gt;session.referer_check =&lt;br /&gt;; 如果请求头中的"Referer"字段不包含此处指定的字符串则会话ID将被视为无效。&lt;br /&gt;; 注意：如果请求头中根本不存在"Referer"字段的话，会话ID将仍将被视为有效。&lt;br /&gt;; 默认为空，即不做检查(全部视为有效)。&lt;/p&gt;&#xD;
&lt;p&gt;session.entropy_file =&amp;nbsp;&amp;nbsp;;"/dev/urandom"&lt;br /&gt;; 附加的用于创建会话ID的外部高熵值资源(文件)，&lt;br /&gt;; 例如UNIX系统上的"/dev/random"或"/dev/urandom"&lt;/p&gt;&#xD;
&lt;p&gt;session.entropy_length = 0&lt;br /&gt;; 从高熵值资源中读取的字节数(建议值：16)。&lt;/p&gt;&#xD;
&lt;p&gt;session.use_cookies = On&lt;br /&gt;; 是否使用cookie在客户端保存会话ID&lt;/p&gt;&#xD;
&lt;p&gt;session.use_only_cookies = Off&lt;br /&gt;; 是否仅仅使用cookie在客户端保存会话ID。PHP6的默认值为On。&lt;br /&gt;; 打开这个选项可以避免使用URL传递会话带来的安全问题。&lt;br /&gt;; 但是禁用Cookie的客户端将使会话无法工作。&lt;/p&gt;&#xD;
&lt;p&gt;session.cookie_lifetime = 0&lt;br /&gt;; 传递会话ID的Cookie有效期(秒)，0 表示仅在浏览器打开期间有效。&lt;br /&gt;; [提示]如果你不能保证服务器时间和客户端时间严格一致请不要改变此默认值！&lt;/p&gt;&#xD;
&lt;p&gt;session.cookie_path = "/"&lt;br /&gt;; 传递会话ID的Cookie作用路径。&lt;/p&gt;&#xD;
&lt;p&gt;session.cookie_domain =&lt;br /&gt;; 传递会话ID的Cookie作用域。&lt;br /&gt;; 默认为空表示表示根据cookie规范生成的主机名。&lt;/p&gt;&#xD;
&lt;p&gt;session.cookie_secure = Off&lt;br /&gt;; 是否仅仅通过安全连接(https)发送cookie。&lt;/p&gt;&#xD;
&lt;p&gt;session.cookie_httponly = Off&lt;br /&gt;; 是否在cookie中添加httpOnly标志(仅允许HTTP协议访问)，&lt;br /&gt;; 这将导致客户端脚本(JavaScript等)无法访问该cookie。&lt;br /&gt;; 打开该指令可以有效预防通过XSS攻击劫持会话ID。&lt;/p&gt;&#xD;
&lt;p&gt;session.cache_limiter = "nocache"&lt;br /&gt;; 设为{nocache|private|public}以指定会话页面的&lt;span &gt;缓存&lt;/span&gt;控制模式，&lt;br /&gt;; 或者设为空以阻止在http应答头中发送禁用缓存的命令。&lt;/p&gt;&#xD;
&lt;p&gt;session.cache_expire = 180&lt;br /&gt;; 指定会话页面在客户端cache中的有效期限(分钟)&lt;br /&gt;; session.cache_limiter=nocache时，此处设置无效。&lt;/p&gt;&#xD;
&lt;p&gt;session.use_trans_sid = Off&lt;br /&gt;; 是否使用明码在URL中显示SID(会话ID)。&lt;br /&gt;; 默认是禁止的，因为它会给你的用户带来安全危险：&lt;br /&gt;; 1- 用户可能将包含有效sid的URL通过email/irc/QQ/MSN...途径告诉给其他人。&lt;br /&gt;; 2- 包含有效sid的URL可能会被保存在公用电脑上。&lt;br /&gt;; 3- 用户可能保存带有固定不变sid的URL在他们的收藏夹或者浏览历史纪录里面。&lt;br /&gt;; 基于URL的会话管理总是比基于Cookie的会话管理有更多的风险，所以应当禁用。&lt;/p&gt;&#xD;
&lt;p&gt;session.bug_compat_42 = On&lt;br /&gt;session.bug_compat_warn = On&lt;br /&gt;; PHP4.2之前的版本有一个未注明的"BUG"：&lt;br /&gt;; 即使在register_globals=Off的情况下也允许初始化全局session变量，&lt;br /&gt;; 如果你在PHP4.3之后的版本中使用这个特性，会显示一条警告。&lt;br /&gt;; 建议关闭该"BUG"并显示警告。PHP6删除了这两个指令，相当于全部设为Off。&lt;/p&gt;&#xD;
&lt;p&gt;session.hash_function = 0&lt;br /&gt;; 生成SID的散列算法。SHA-1的安全性更高一些&lt;br /&gt;; 0: MD5&amp;nbsp; &amp;nbsp;(128 bits)&lt;br /&gt;; 1: SHA-1 (160 bits)&lt;br /&gt;; 建议使用SHA-1。&lt;/p&gt;&#xD;
&lt;p&gt;session.hash_bits_per_character = 4&lt;br /&gt;; 指定在SID字符串中的每个字符内保存多少bit，&lt;br /&gt;; 这些二进制数是hash函数的运算结果。&lt;br /&gt;; 4: 0-9, a-f&lt;br /&gt;; 5: 0-9, a-v&lt;br /&gt;; 6: 0-9, a-z, A-Z, "-", ","&lt;br /&gt;; 建议值为 5&lt;/p&gt;&#xD;
&lt;p&gt;url_rewriter.tags = "a=href,area=href,frame=src,form=,fieldset="&lt;br /&gt;; 此指令属于PHP核心部分，并不属于Session模块。&lt;br /&gt;; 指定重写哪些HTML标签来包含SID(仅当session.use_trans_sid=On时有效)&lt;br /&gt;; form和fieldset比较特殊：&lt;br /&gt;; 如果你包含他们，URL重写器将添加一个隐藏的"&amp;lt;input&amp;gt;"，它包含了本应当额外追加到URL上的信息。&lt;br /&gt;; 如果要符合XHTML标准，请去掉form项并在表单字段前后加上&amp;lt;fieldset&amp;gt;标记。&lt;br /&gt;; 注意：所有合法的项都需要一个等号(即使后面没有值)。&lt;br /&gt;; 推荐值为"a=href,area=href,frame=src,input=src,form=fakeentry"。&lt;/p&gt;&#xD;
&lt;p&gt;session.encode_sources = "globals"&lt;br /&gt;; PHP6中有争议的指令，尚未决定是否采用该指令。也尚无相关文档。&lt;/p&gt;&#xD;
&lt;p&gt;&lt;br /&gt;;;;;;;;;;;;;;;;;&lt;br /&gt;;;&amp;nbsp;&amp;nbsp;其他模块&amp;nbsp;&amp;nbsp;;;&lt;br /&gt;;;;;;;;;;;;;;;;;&lt;/p&gt;&#xD;
&lt;p&gt;[APC-3.0.16]&lt;br /&gt;; Alternative PHP Cache 用于缓存和优化PHP中间代码&lt;br /&gt;; 编译/安装/配置信息都位于源码树下的 INSTALL 文件中&lt;/p&gt;&#xD;
&lt;p&gt;apc.enabled = On&lt;br /&gt;; 是否启用APC，如果APC被静态编译进PHP又想禁用它，这是唯一的办法。&lt;/p&gt;&#xD;
&lt;p&gt;apc.enable_cli = Off&lt;br /&gt;; 是否为CLI版本启用APC功能，仅用于测试和调试目的才打开此指令。&lt;/p&gt;&#xD;
&lt;p&gt;apc.cache_by_default = On&lt;br /&gt;; 是否默认对所有文件启用缓冲。&lt;br /&gt;; 若设为Off并与以加号开头的apc.filters指令一起用，则文件仅在匹配过滤器时才被缓存。&lt;/p&gt;&#xD;
&lt;p&gt;apc.file_update_protection = 2&lt;br /&gt;; 当你在一个运行中的服务器上修改文件时，你应当执行原子操作。&lt;br /&gt;; 也就是先写进一个临时文件，然后将该文件重命名(mv)到最终的名字。&lt;br /&gt;; 文本编辑器以及 cp, tar 等程序却并不是这样操作的，从而导致有可能缓冲了残缺的文件。&lt;br /&gt;; 默认值 2 表示在访问文件时如果发现修改时间距离访问时间小于 2 秒则不做缓冲。&lt;br /&gt;; 那个不幸的访问者可能得到残缺的内容，但是这种坏影响却不会通过缓存扩大化。&lt;br /&gt;; 如果你能确保所有的更新操作都是原子操作，那么可以用 0 关闭此特性。&lt;br /&gt;; 如果你的系统由于大量的IO操作导致更新缓慢，你就需要增大此值。&lt;/p&gt;&#xD;
&lt;p&gt;apc.filters =&lt;br /&gt;; 一个以逗号分隔的POSIX扩展正则表达式列表。&lt;br /&gt;; 如果源文件名与任意一个模式匹配，则该文件不被缓存。&lt;br /&gt;; 注意，用来匹配的文件名是传递给include/require的文件名，而不是绝对路径。&lt;br /&gt;; 如果正则表达式的第一个字符是"+"则意味着任何匹配表达式的文件会被缓存，&lt;br /&gt;; 如果第一个字符是"-"则任何匹配项都不会被缓存。"-"是默认值，可以省略掉。&lt;/p&gt;&#xD;
&lt;p&gt;apc.ttl = 0&lt;br /&gt;; 缓存条目在缓冲区中允许逗留的秒数。0 表示永不超时。建议值为7200~86400。&lt;br /&gt;; 设为 0 意味着缓冲区有可能被旧的缓存条目填满，从而导致无法缓存新条目。&lt;/p&gt;&#xD;
&lt;p&gt;apc.user_ttl = 0&lt;br /&gt;; 类似于apc.ttl，只是针对每个用户而言，建议值为7200~86400。&lt;br /&gt;; 设为 0 意味着缓冲区有可能被旧的缓存条目填满，从而导致无法缓存新条目。&lt;/p&gt;&#xD;
&lt;p&gt;apc.gc_ttl = 3600&lt;br /&gt;; 缓存条目在垃圾回收表中能够存在的秒数。&lt;br /&gt;; 此值提供了一个安全措施，即使一个服务器进程在执行缓存的源文件时崩溃，&lt;br /&gt;; 而且该源文件已经被修改，为旧版本分配的内存也不会被回收，直到达到此TTL值为止。&lt;br /&gt;; 设为零将禁用此特性。&lt;/p&gt;&#xD;
&lt;p&gt;apc.include_once_override = Off&lt;br /&gt;; 优化include_once()和require_once()函数以避免执行额外的系统调用。&lt;/p&gt;&#xD;
&lt;p&gt;apc.max_file_size = 1M&lt;br /&gt;; 禁止大于此尺寸的文件被缓存。&lt;/p&gt;&#xD;
&lt;p&gt;apc.mmap_file_mask =&lt;br /&gt;; 如果使用--enable-mmap(默认启用)为APC编译了MMAP支持，&lt;br /&gt;; 这里的值就是传递给mmap模块的mktemp风格的文件掩码(建议值为"/tmp/apc.XXXXXX")。&lt;br /&gt;; 该掩码用于决定内存映射区域是否要被file-backed或者shared memory backed。&lt;br /&gt;; 对于直接的file-backed内存映射，要设置成"/tmp/apc.XXXXXX"的样子(恰好6个X)。&lt;br /&gt;; 要使用POSIX风格的shm_open/mmap就需要设置成"/apc.shm.XXXXXX"的样子。&lt;br /&gt;; 你还可以设为"/dev/zero"来为匿名映射的内存使用内核的"/dev/zero"接口。&lt;br /&gt;; 不定义此指令则表示强制使用匿名映射。&lt;/p&gt;&#xD;
&lt;p&gt;apc.num_files_hint = 1000&lt;br /&gt;; Web服务器上可能被包含或被请求的不同脚本源代码文件的大致数量(建议值为1024~4096)。&lt;br /&gt;; 如果你不能确定，则设为 0 ；此设定主要用于拥有数千个源文件的站点。&lt;/p&gt;&#xD;
&lt;p&gt;apc.optimization = 0&lt;br /&gt;; 优化级别(建议值为 0 ) 。反对使用该指令。将来可能会被删除。&lt;br /&gt;; 正整数值表示启用优化器，值越高则使用越激进的优化。&lt;br /&gt;; 更高的值可能有非常有限的速度提升，但目前尚在试验中。&lt;/p&gt;&#xD;
&lt;p&gt;apc.report_autofilter = Off&lt;br /&gt;; 是否记录所有由于early/late binding原因而自动未被缓存的脚本。&lt;/p&gt;&#xD;
&lt;p&gt;apc.shm_segments = 1&lt;br /&gt;; 为编译器缓冲区分配的共享内存块数量(建议值为1)。&lt;br /&gt;; 如果APC耗尽了共享内存，并且已将apc.shm_size指令设为系统允许的最大值，可以尝试增大此值。&lt;br /&gt;; 在mmap模式下设置为 1 之外的其它值是无效的，因为经过mmap的共享内存段的大小是没有限制的。&lt;/p&gt;&#xD;
&lt;p&gt;apc.shm_size = 30&lt;br /&gt;; 每个共享内存块的大小(以MB为单位，建议值为128~256)。&lt;br /&gt;; 有些系统(包括大多数BSD变种)默认的共享内存块尺寸很小。&lt;/p&gt;&#xD;
&lt;p&gt;apc.slam_defense = 0&lt;br /&gt;; 在非常繁忙的服务器上，无论是启动服务还是修改文件，&lt;br /&gt;; 都可能由于多个进程企图同时缓存一个文件而导致竞争&lt;span &gt;条件&lt;/span&gt;。&lt;br /&gt;; 这个指令用于设置进程在处理未被缓存的文件时跳过缓存步骤的百分率。&lt;br /&gt;; 比如设为75表示在遇到未被缓存的文件时有75%的概率不进行缓存，从而减少碰撞几率。&lt;br /&gt;; 反对使用该指令，鼓励设为 0 来禁用这个特性。建议该用apc.write_lock指令。&lt;/p&gt;&#xD;
&lt;p&gt;apc.stat = On&lt;br /&gt;; 是否启用脚本更新检查。&lt;br /&gt;; 改变这个指令值要非常小心。&lt;br /&gt;; 默认值 On 表示APC在每次请求脚本时都检查脚本是否被更新，&lt;br /&gt;; 如果被更新则自动重新编译和缓存编译后的内容。但这样做对性能有不利影响。&lt;br /&gt;; 如果设为 Off 则表示不进行检查，从而使性能得到大幅提高。&lt;br /&gt;; 但是为了使更新的内容生效，你必须重启Web服务器。&lt;br /&gt;; 这个指令对于include/require的文件同样有效。但是需要注意的是，&lt;br /&gt;; 如果你使用的是相对路径，APC就必须在每一次include/require时都进行检查以定位文件。&lt;br /&gt;; 而使用绝对路径则可以跳过检查，所以鼓励你使用绝对路径进行include/require操作。&lt;/p&gt;&#xD;
&lt;p&gt;apc.user_entries_hint = 4096&lt;br /&gt;; 类似于num_files_hint指令，只是针对每个不同用户而言。&lt;br /&gt;; 如果你不能确定，则设为 0 。&lt;/p&gt;&#xD;
&lt;p&gt;apc.write_lock = On&lt;br /&gt;; 是否启用写入锁。&lt;br /&gt;; 在非常繁忙的服务器上，无论是启动服务还是修改文件，&lt;br /&gt;; 都可能由于多个进程企图同时缓存一个文件而导致竞争条件。&lt;br /&gt;; 启用该指令可以避免竞争条件的出现。&lt;/p&gt;&#xD;
&lt;p&gt;apc.rfc1867 = Off&lt;br /&gt;; 打开该指令后，对于每个恰好在file字段之前含有APC_UPLOAD_PROGRESS字段的上传文件，&lt;br /&gt;; APC都将自动创建一个upload_&amp;lt;key&amp;gt;的用户缓存条目(&amp;lt;key&amp;gt;就是APC_UPLOAD_PROGRESS字段值)。&lt;br /&gt;; 需要注意的是，文件上传跟踪在这里并不是线程安全的，&lt;br /&gt;; 所以如果老文件尚未上载完毕且新文件已经开始上载，那么将丢失对老文件的跟踪。&lt;/p&gt;&#xD;
&lt;p&gt;apc.rfc1867_prefix = "upload_"&lt;br /&gt;; 用于rfc1867上传文件的缓冲项条目名称前缀&lt;/p&gt;&#xD;
&lt;p&gt;apc.rfc1867_name = "APC_UPLOAD_PROGRESS"&lt;br /&gt;; 需要由APC处理的上传文件的rfc1867隐含表单项名称&lt;/p&gt;&#xD;
&lt;p&gt;apc.rfc1867_freq = 0&lt;br /&gt;; 用户rfc1867上传文件缓存项的更新频率。&lt;br /&gt;; 取值可以是总文件大小的百分比，或者以'K','M','G'结尾的绝对尺寸。&lt;br /&gt;; 0 表示尽可能快的更新，不过这样可能会导致运行速度下降。&lt;/p&gt;&#xD;
&lt;p&gt;apc.localcache = Off&lt;br /&gt;; 是否使用非锁定本地进程shadow-cache ，它可以减少了向缓冲区写入时锁之间的竞争。&lt;/p&gt;&#xD;
&lt;p&gt;apc.localcache.size = 512&lt;br /&gt;; 本地进程的shadow-cache，应当设为一个足够大的值，大约相当于num_files_hint的一半。&lt;/p&gt;&#xD;
&lt;p&gt;apc.stat_ctime = Off&lt;br /&gt;; 尚无文档&lt;/p&gt;&#xD;
&lt;p&gt;&lt;br /&gt;[bcmath]&lt;br /&gt;; 为任意精度数学计算提供了二进制计算器(Binary Calculator)，&lt;br /&gt;; 它支持任意大小和精度的数字，以字符串形式描述。&lt;/p&gt;&#xD;
&lt;p&gt;bcmath.scale = 0&lt;br /&gt;; 用于所有bcmath函数的10十进制数的个数&lt;/p&gt;&#xD;
&lt;p&gt;&lt;br /&gt;[GD]&lt;/p&gt;&#xD;
&lt;p&gt;gd.jpeg_ignore_warning = Off&lt;br /&gt;; 是否忽略jpeg解码器的警告信息(比如无法识别图片格式)。&lt;br /&gt;; 有image/jpeg与image/pjpeg两种MIME类型，GD库只能识别前一种传统格式。&lt;br /&gt;; 参见：&lt;a href="http://twpug.net/modules/newbb/viewtopic.php?topic_id=1867&amp;amp;amp" target="_blank"&gt;http://twpug.net/modules/newbb/v ... pic_id=1867&amp;amp;amp&lt;/a&gt;;forum=14&lt;br /&gt;; &lt;a href="http://bugs.php.net/bug.php?id=29878" target="_blank"&gt;http://bugs.php.net/bug.php?id=29878&lt;/a&gt;&lt;br /&gt;; &lt;a href="http://www.faqs.org/faqs/jpeg-faq/part1/section-11.html" target="_blank"&gt;http://www.faqs.org/faqs/jpeg-faq/part1/section-11.html&lt;/a&gt;&lt;/p&gt;&#xD;
&lt;p&gt;&lt;br /&gt;[Filter]&lt;br /&gt;; 对来源不可靠的数据进行确认和过滤，本扩展模块是实验性的。&lt;/p&gt;&#xD;
&lt;p&gt;filter.default = "unsafe_raw"&lt;br /&gt;; 使用指定的过滤器过滤$_GET,$_POST,$_COOKIE,$_REQUEST数据，&lt;br /&gt;; 原始数据可以通过input_get()函数访问。&lt;br /&gt;; "unsafe_raw"表示不做任何过滤。&lt;/p&gt;&#xD;
&lt;p&gt;filter.default_flags =&lt;br /&gt;; filter_data()函数的默认标志。&lt;/p&gt;&#xD;
&lt;p&gt;&lt;br /&gt;[mbstring]&lt;br /&gt;;多字节字符串模块支持&lt;/p&gt;&#xD;
&lt;p&gt;mbstring.language = "neutral"&lt;br /&gt;; 默认的NLS(本地语言设置)，可设置值如下：&lt;br /&gt;; 默认值"neutral"表示中立，相当于未知。&lt;br /&gt;; "zh-cn"或"Simplified Chinese"表示简体&lt;span &gt;中文&lt;/span&gt;&lt;br /&gt;; "zh-tw"或"Traditional Chinese"表示繁体中文&lt;br /&gt;; "uni"或"universal"表示Unicode&lt;br /&gt;; 该指令自动定义了随后的mbstring.internal_encoding指令默认值，&lt;br /&gt;; 并且mbstring.internal_encoding指令必须放置在该指令之后。&lt;/p&gt;&#xD;
&lt;p&gt;mbstring.internal_encoding =&lt;br /&gt;; 本指令必须放置在mbstring.language指令之后。&lt;br /&gt;; 默认的内部编码，未设置时取决于mbstring.language指令的值：&lt;br /&gt;; "neutral" 对应 "ISO-8859-1"&lt;br /&gt;; "zh-cn"&amp;nbsp; &amp;nbsp;对应 "EUC-CN" (等价于"GB2312")&lt;br /&gt;; "zh-tw"&amp;nbsp; &amp;nbsp;对应 "EUC-TW" (等价于"BIG5")&lt;br /&gt;; "uni"&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp;对应 "UTF-8"&lt;br /&gt;; 提醒：对于简体中文还可以强制设置为"CP936" (等价于"GBK")&lt;br /&gt;; 注意：可能 SJIS, BIG5, GBK 不适合作为内部编码，不过"GB2312"肯定没问题。&lt;br /&gt;; 建议手动强制指定&lt;/p&gt;&#xD;
&lt;p&gt;mbstring.encoding_translation = Off&lt;br /&gt;; 是否对进入的HTTP请求按照mbstring.internal_encoding指令进行透明的编码转换，&lt;br /&gt;; 也就是自动检测输入字符的编码并将其透明的转化为内部编码。&lt;br /&gt;; 可移植的库或者程序千万不要依赖于自动编码转换。&lt;/p&gt;&#xD;
&lt;p&gt;mbstring.http_input = "pass"&lt;br /&gt;; 默认的HTTP输入编码，"pass"表示跳过(不做转换)&lt;br /&gt;; "aotu"的含义与mbstring.detect_order指令中的解释一样。&lt;br /&gt;; 可以设置为一个单独的值，也可以设置为一个逗号分隔的列表。&lt;/p&gt;&#xD;
&lt;p&gt;mbstring.http_output = "pass"&lt;br /&gt;; 默认的HTTP输出编码，"pass"表示跳过(不做转换)&lt;br /&gt;; "aotu"的含义与mbstring.detect_order指令中的解释一样。&lt;br /&gt;; 可以设置为一个单独的值，也可以设置为一个逗号分隔的列表。&lt;br /&gt;; 必须将output_handler指令设置为"mb_output_handler"才可以。&lt;/p&gt;&#xD;
&lt;p&gt;mbstring.detect_order =&lt;br /&gt;; 默认的编码检测顺序，"pass"表示跳过(不做转换)。&lt;br /&gt;; 默认值("auto")随mbstring.language指令的不同而变化：&lt;br /&gt;; "neutral"和"universal" 对应 "ASCII, UTF-8"&lt;br /&gt;; "Simplified Chinese"&amp;nbsp; &amp;nbsp;对应 "ASCII, UTF-8, EUC-CN, CP936"&lt;br /&gt;; "Traditional Chinese"&amp;nbsp;&amp;nbsp;对应 "ASCII, UTF-8, EUC-TW, BIG-5"&lt;br /&gt;; 建议在可控环境下手动强制指定一个单一值&lt;/p&gt;&#xD;
&lt;p&gt;mbstring.func_overload = 0&lt;br /&gt;; 自动使用 mb_* 函数重载相应的单字节字符串函数。&lt;br /&gt;; 比如：mail(), ereg() 将被自动替换为mb_send_mail(), mb_ereg()&lt;br /&gt;; 可用 0,1,2,4 进行位组合。比如7表示替换所有。具体替换说明如下：&lt;br /&gt;; 0: 无替换&lt;br /&gt;; 1: mail() &amp;rarr; mb_send_mail()&lt;br /&gt;; 2: strlen() &amp;rarr; mb_strlen() ; substr() &amp;rarr; mb_substr()&lt;br /&gt;;&amp;nbsp; &amp;nbsp; strpos() &amp;rarr; mb_strpos() ; strrpos() &amp;rarr; mb_strrpos()&lt;br /&gt;;&amp;nbsp; &amp;nbsp; strtolower() &amp;rarr; mb_strtolower() ; strtoupper() &amp;rarr; mb_strtoupper()&lt;br /&gt;;&amp;nbsp; &amp;nbsp; substr_count() &amp;rarr; mb_substr_count()&lt;br /&gt;; 4: ereg() &amp;rarr; mb_ereg() ; eregi() &amp;rarr; mb_eregi()&lt;br /&gt;;&amp;nbsp; &amp;nbsp; ereg_replace() &amp;rarr; mb_ereg_replace() ; eregi_replace() &amp;rarr; mb_eregi_replace()&lt;br /&gt;;&amp;nbsp; &amp;nbsp; split() &amp;rarr; mb_split()&lt;/p&gt;&#xD;
&lt;p&gt;mbstring.script_encoding =&lt;br /&gt;; 脚本所使用的编码&lt;/p&gt;&#xD;
&lt;p&gt;mbstring.strict_detection = Off&lt;br /&gt;; 是否使用严谨的编码检测&lt;/p&gt;&#xD;
&lt;p&gt;mbstring.substitute_character =&lt;br /&gt;; 当某个字符无法解码时，就是用这个字符替代。&lt;br /&gt;; 若设为一个整数则表示对应的Unicode值，不设置任何值表示不显示这个错误字符。&lt;br /&gt;; 建议设为"□"&lt;/p&gt;&#xD;
&lt;p&gt;&lt;br /&gt;[Mcrypt]&lt;br /&gt;; 一个mcrypt库的接口，该库支持许多种块加密算法。&lt;br /&gt;; 不建议使用该模块，因为毛病太多，建议在数据库层进行加密。&lt;/p&gt;&#xD;
&lt;p&gt;mcrypt.algorithms_dir =&lt;br /&gt;; 默认的加密算法模块所在目录。通常是"/usr/local/lib/libmcrypt"。&lt;br /&gt;; 目前尚无详细说明文档，此处的解释可能是错误的。&lt;/p&gt;&#xD;
&lt;p&gt;mcrypt.modes_dir =&lt;br /&gt;; 默认的加密模式模块所在目录。通常是"/usr/local/lib/libmcrypt"。&lt;br /&gt;; 目前尚无说明文档，此处的解释可能是错误的。&lt;/p&gt;&#xD;
&lt;p&gt;&lt;br /&gt;[Memcache-2.2.2]&lt;br /&gt;; 一个高性能的分布式的内存对象缓存系统，通过在内存里维护一个统一的巨大的hash表，&lt;br /&gt;; 它能够用来存储各种格式的数据，包括图像、视频、文件以及数据库检索的结果等。&lt;/p&gt;&#xD;
&lt;p&gt;memcache.allow_failover = On&lt;br /&gt;; 是否在遇到错误时透明地向其他服务器进行故障转移。&lt;/p&gt;&#xD;
&lt;p&gt;memcache.chunk_size = 8192&lt;br /&gt;; 数据将按照此值设定的块大小进行转移。此值越小所需的额外网络传输越多。&lt;br /&gt;; 如果发现无法解释的速度降低，可以尝试将此值增加到32768。&lt;/p&gt;&#xD;
&lt;p&gt;memcache.default_port = 11211&lt;br /&gt;; 连接到memcached服务器时使用的默认TCP端口。&lt;/p&gt;&#xD;
&lt;p&gt;memcache.max_failover_attempts = 20&lt;br /&gt;; 接受和发送数据时最多尝试多少个服务器，进在打开memcache.allow_failover时有效。&lt;/p&gt;&#xD;
&lt;p&gt;memcache.hash_strategy = "standard"&lt;br /&gt;; 控制将key映射到server的策略。默认值"standard"表示使用先前版本的老hash策略。&lt;br /&gt;; 设为"consistent"可以允许在连接池中添加/删除服务器时不必重新计算key与server之间的映射关系。&lt;/p&gt;&#xD;
&lt;p&gt;memcache.hash_function = "crc32"&lt;br /&gt;; 控制将key映射到server的散列函数。默认值"crc32"使用CRC32算法，而"fnv"则表示使用FNV-1a算法。&lt;br /&gt;; FNV-1a比CRC32速度稍低，但是散列效果更好。&lt;/p&gt;&#xD;
&lt;p&gt;&lt;br /&gt;[Zlib]&lt;br /&gt;; 该模块允许PHP透明的读取和写入gzip(.gz)压缩文件。&lt;/p&gt;&#xD;
&lt;p&gt;zlib.output_compression = Off&lt;br /&gt;; 是否使用zlib库透明地压缩脚本输出结果。&lt;br /&gt;; 该指令的值可以设置为：Off、On、字节数(压缩缓冲区大小，默认为4096)。&lt;br /&gt;; 如果打开该指令，当浏览器发送"Accept-Encoding: gzip(deflate)"头时，&lt;br /&gt;; "Content-Encoding: gzip(deflate)"和"Vary: Accept-Encoding"头将加入到应答头当中。&lt;br /&gt;; 你可以在应答头输出之前用ini_set()函数在脚本中启用或禁止这个特性。&lt;br /&gt;; 如果输出一个"Content-Type: image/??"这样的应答头，压缩将不会启用(为了防止Netscape的bug)。&lt;br /&gt;; 你可以在输出"Content-Type: image/??"之后使用"ini_set('zlib.output_compression', 'On')"重新打开这个特性。&lt;br /&gt;; 注意1: 压缩率会受压缩缓冲区大小的影响，如果你想得到更好的压缩质量，请指定一个较大的压缩缓冲区。&lt;br /&gt;; 注意2: 如果启用了zlib输出压缩，output_handler指令必须为空，同时必须设置zlib.output_handler指令的值。&lt;/p&gt;&#xD;
&lt;p&gt;zlib.output_compression_level = -1&lt;br /&gt;; 压缩级别，可用值为 0~9 ，0表示不压缩。值越高效果越好，但CPU占用越多，建议值为1~5。&lt;br /&gt;; 默认值 -1 表示使用zlib内部的默认值(6)。&lt;/p&gt;&#xD;
&lt;p&gt;zlib.output_handler =&lt;br /&gt;; 在打开zlib.output_compression指令的情况下，你只能在这里指定输出处理器。&lt;br /&gt;; 可以使用的处理器有"zlib.inflate"(解压)或"zlib.deflate"(压缩)。&lt;br /&gt;; 如果启用该指令则必须将output_handler指令设为空。&lt;/p&gt;&#xD;
&lt;p&gt;&lt;br /&gt;[dbx]&lt;br /&gt;; 一个数据库抽象层，为不同数据库提供了统一的接口。目前支持：&lt;br /&gt;; FrontBase,SQL Server,MySQL,ODBC,PostgreSQL,Sybase-CT,Oracle 8,SQLite&lt;/p&gt;&#xD;
&lt;p&gt;dbx.colnames_case = "unchanged"&lt;br /&gt;; 字段名可以按照"unchanged"或"uppercase","lowercase"方式返回。&lt;/p&gt;&#xD;
&lt;p&gt;&lt;br /&gt;[MySQLi]&lt;br /&gt;; MySQLi模块只能与4.1.3以上版本的MySQL一起工作。&lt;/p&gt;&#xD;
&lt;p&gt;mysqli.max_links = -1&lt;br /&gt;; 每个进程中允许的最大连接数(持久和非持久)。-1 代表无限制&lt;/p&gt;&#xD;
&lt;p&gt;mysqli.default_port = 3306&lt;br /&gt;; mysqli_connect()连接到MySQL数据库时使用的默认TCP端口。&lt;br /&gt;; 如果没有在这里指定默认值，将按如下顺序寻找：&lt;br /&gt;; (1)$&lt;span &gt;MYSQL&lt;/span&gt;_TCP_PORT环境变量&lt;br /&gt;; (2)/etc/services文件中的mysql-tcp项(unix)&lt;br /&gt;; (3)编译时指定的MYSQL_PORT常量&lt;br /&gt;; 注意：Win32下，只使用MYSQL_PORT常量。&lt;/p&gt;&#xD;
&lt;p&gt;mysqli.default_socket =&lt;br /&gt;; mysqli_connect()连接到本机MySQL服务器时所使用的默认套接字名。&lt;br /&gt;; 若未指定则使用内置的MqSQL默认值。&lt;/p&gt;&#xD;
&lt;p&gt;mysqli.default_host =&lt;br /&gt;; mysqli_connect()连接到MySQL数据库时使用的默认主机。安全模式下无效。&lt;/p&gt;&#xD;
&lt;p&gt;mysqli.default_user =&lt;br /&gt;; mysqli_connect()连接到MySQL数据库时使用的默认用户名。安全模式下无效。&lt;/p&gt;&#xD;
&lt;p&gt;mysqli.default_pw =&lt;br /&gt;; mysqli_connect()连接到MySQL数据库时使用的默认密码。安全模式下无效。&lt;br /&gt;; 在配置文件中保存密码是个坏主意，任何使用PHP权限的用户都可以运行&lt;br /&gt;; 'echo cfg_get_var("mysql.default_password")'来显示密码!&lt;br /&gt;; 而且任何对该配置文件有读权限的用户也能看到密码。&lt;/p&gt;&#xD;
&lt;p&gt;mysqli.reconnect = Off&lt;br /&gt;; 是否允许重新连接&lt;/p&gt;&#xD;
&lt;p&gt;&lt;br /&gt;[PostgresSQL]&lt;br /&gt;;PostgresSQL模块建议与8.0以上版本一起工作。&lt;/p&gt;&#xD;
&lt;p&gt;pgsql.allow_persistent = On&lt;br /&gt;; 是否允许持久连接&lt;/p&gt;&#xD;
&lt;p&gt;pgsql.max_persistent = -1&lt;br /&gt;; 每个进程中允许的最大持久连接数。-1 代表无限制。&lt;/p&gt;&#xD;
&lt;p&gt;pgsql.max_links = -1&lt;br /&gt;; 每个进程中允许的最大连接数(持久和非持久)。-1 代表无限制。&lt;/p&gt;&#xD;
&lt;p&gt;pgsql.auto_reset_persistent = Off&lt;br /&gt;; 自动复位在pg_pconnect()上中断了的持久连接，检测需要一些额外开销。&lt;/p&gt;&#xD;
&lt;p&gt;pgsql.ignore_notice = Off&lt;br /&gt;; 是否忽略PostgreSQL后端的提醒消息。&lt;br /&gt;; 记录后端的提醒消息需要一些很小的额外开销。&lt;/p&gt;&#xD;
&lt;p&gt;pgsql.log_notice = Off&lt;br /&gt;; 是否在日志中记录PostgreSQL后端的提醒消息。&lt;br /&gt;; 仅在pgsql.ignore_notice=Off时，才可以记录。&lt;/p&gt;&lt;img src="http://www.cnblogs.com/kaixin110/aggbug/1866916.html?type=1" width="1" height="1" alt=""/&gt;&lt;p&gt;&lt;a href="http://www.cnblogs.com/kaixin110/archive/2010/11/02/1866916.html" target="_blank"&gt;本文链接&lt;/a&gt;&lt;/p&gt;</content></entry></feed>
