一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

Fatal error: session_start(): Failed to initialize storage module: files問題解決方法

之前編譯安裝的LNMP環(huán)境+phpmyamdin4.02的版本,今天突然出現(xiàn)這個(gè)問題:
復(fù)制代碼 代碼如下:Fatal error: session_start(): Failed to initialize storage module: files (path: ) in /data/www/phpmyadmin/libraries/session.inc.php on line 83
大致意思是session會(huì)話初始化的時(shí)候儲(chǔ)存路徑有誤!第一反應(yīng)就是查看php.ini的配置文件中的:
復(fù)制代碼 代碼如下:session.save_path = "/tmp"
默認(rèn)前面是加的分號(hào),表示不啟用,我之前配置的時(shí)候已經(jīng)啟用了。那為什么還會(huì)報(bào)錯(cuò)呢?,于是網(wǎng)上找了一些資料,感覺都千篇一律:

1、檢查error.log(Apache2.2/logs)文件,查看是否有錯(cuò)誤報(bào)告。未發(fā)現(xiàn)。
2、檢查php.ini中的session.save_handler的值是否為files,如果不是改為files
3、檢查php.ini文件中session.save_path是否被注釋了,如果有,則去掉前面的”;”。
4、將save_path后面的路徑改成已有的路徑,比如”D:/php/temp”
5、檢查temp文件夾的屬性是否可讀可寫。
6、重啟APACHE服務(wù)器。OK

不知道那些哥們轉(zhuǎn)載的時(shí)候自己試過了沒有(在這里噴一下,最討厭那種自己都沒有親測,就一股腦的轉(zhuǎn)來轉(zhuǎn)去。一點(diǎn)都不負(fù)責(zé)!)
根據(jù)上面的流程,排查了之后發(fā)現(xiàn)壓根就沒有解決,不過小編的服務(wù)器是nginx非apache。
然后自己寫了一個(gè)腳本test.php
復(fù)制代碼 代碼如下:
$r = session_start();
var_dump($r);
打印結(jié)果為:
復(fù)制代碼 代碼如下:
Warning: session_start(): SAFE MODE Restriction in effect. The script whose uid is 501 is not allowed to access /tmp owned by uid 0 in /data/www/test.php on line 3 Fatal error: session_start(): Failed to initialize storage module: files (path: ) in /data/www/test.php on line 3

意思是 php5一個(gè)安全模式的bug,默認(rèn)session的save_path是系統(tǒng)的臨時(shí)目錄,這樣會(huì)要校驗(yàn)權(quán)限。而這個(gè)腳本不能通過/tmp擁有者uid為0來執(zhí)行uid是501也是www用戶組的權(quán)限
解決這個(gè)有兩種解決方法:

1.關(guān)閉安全模式;
2.在命令行下chown改文件/目錄的擁有者

當(dāng)然兩種方法都要求你有服務(wù)器的權(quán)限。
下面是示例php.ini的配置文件:

復(fù)制代碼 代碼如下:
[Session]
 ; Handler used to store/retrieve data.
 ; http://php.NET/session.save-handler
session.save_handler = files; Argument passed to save_handler.  In the case of files, this is the path
 ; where data files are stored. Note: Windows users have to change this
 ; variable in order to use php's session functions.

 ; The path can be defined as:

 ;     session.save_path = "N;/path"

 ; where N is an integer.  Instead of storing all the session files in
 ; /path, what this will do is use subdirectories N-levels deep, and
 ; store the session data in those directories.  This is useful if you
 ; or your OS have problems with lots of files in one directory, and is
 ; a more efficient layout for servers that handle lots of sessions.

 ; NOTE 1: php will not create this directory structure automatically.
 ;         You can use the script in the ext/session dir for that purpose.
 ; NOTE 2: See the section on garbage collection below if you choose to
 ;         use subdirectories for session storage

 ; The file storage module creates files using mode 600 by default.
 ; You can change that by using

 ;     session.save_path = "N;MODE;/path"

 ; where MODE is the octal representation of the mode. Note that this
 ; does not overwrite the process's umask.
 ; http://php.NET/session.save-path
 session.save_path = "/tmp"
; Whether to use cookies.
 ; http://php.NET/session.use-cookies
 session.use_cookies = 1
; http://php.NET/session.cookie-secure
 ;session.cookie_secure =
; This option forces php to fetch and use a cookie for storing and maintaining
 ; the session id. We encourage this operation as it's very helpful in combatting
 ; session hijacking when not specifying and managing your own session id. It is
 ; not the end all be all of session hijacking defense, but it's a good start.
 ; http://php.NET/session.use-only-cookies
 session.use_only_cookies = 1
; Name of the session (used as cookie name).
 ; http://php.NET/session.name
 session.name = phpSESSID
; Initialize session on request startup.
 ; http://php.NET/session.auto-start
 session.auto_start = 0
; Lifetime in seconds of cookie or, if 0, until browser is restarted.
 ; http://php.NET/session.cookie-lifetime
 session.cookie_lifetime = 0
; The path for which the cookie is valid.
 ; http://php.NET/session.cookie-path
 session.cookie_path = /
; The domain for which the cookie is valid.
 ; http://php.NET/session.cookie-domain
 session.cookie_domain =
; Whether or not to add the httpOnly flag to the cookie, which makes it inaccessible to browser scripting languages such as JavaScript.
 ; http://php.NET/session.cookie-httponly
 session.cookie_httponly =
; Handler used to serialize data.  php is the standard serializer of php.
 ; http://php.NET/session.serialize-handler
 session.serialize_handler = php
; Defines the probability that the 'garbage collection' process is started
 ; on every session initialization. The probability is calculated by using
 ; gc_probability/gc_divisor. Where session.gc_probability is the numerator
 ; and gc_divisor is the denominator in the equation. Setting this value to 1
 ; when the session.gc_divisor value is 100 will give you approximately a 1% chance
 ; the gc will run on any give request.
 ; Default Value: 1
 ; Development Value: 1
 ; Production Value: 1
 ; http://php.NET/session.gc-probability
 session.gc_probability = 1
; Defines the probability that the 'garbage collection' process is started on every
 ; session initialization. The probability is calculated by using the following equation:
 ; gc_probability/gc_divisor. Where session.gc_probability is the numerator and
 ; session.gc_divisor is the denominator in the equation. Setting this value to 1
 ; when the session.gc_divisor value is 100 will give you approximately a 1% chance
 ; the gc will run on any give request. Increasing this value to 1000 will give you
 ; a 0.1% chance the gc will run on any give request. For high volume production servers,
 ; this is a more efficient approach.
 ; Default Value: 100
 ; Development Value: 1000
 ; Production Value: 1000
 ; http://php.NET/session.gc-divisor
 session.gc_divisor = 1000
; After this number of seconds, stored data will be seen as 'garbage' and
 ; cleaned up by the garbage collection process.
 ; http://php.NET/session.gc-maxlifetime
 session.gc_maxlifetime = 1440
; NOTE: If you are using the subdirectory option for storing session files
 ;       (see session.save_path above), then garbage collection does *not*
 ;       happen automatically.  You will need to do your own garbage
 ;       collection through a shell script, cron entry, or some other method.
 ;       For example, the following script would is the equivalent of
 ;       setting session.gc_maxlifetime to 1440 (1440 seconds = 24 minutes):
 ;          find /path/to/sessions -cmin +24 | xargs rm
; php 4.2 and less have an undocumented feature/bug that allows you to
 ; to initialize a session variable in the global scope, even when register_globals
 ; is disabled.  php 4.3 and later will warn you, if this feature is used.
 ; You can disable the feature and the warning separately. At this time,
 ; the warning is only displayed, if bug_compat_42 is enabled. This feature
 ; introduces some serious security problems if not handled correctly. It's
 ; recommended that you do not use this feature on production servers. But you
 ; should enable this on development servers and enable the warning as well. If you
 ; do not enable the feature on development servers, you won't be warned when it's
 ; used and debugging errors caused by this can be difficult to track down.
 ; Default Value: On
 ; Development Value: On
 ; Production Value: Off
 ; http://php.NET/session.bug-compat-42
 session.bug_compat_42 = Off
; This setting controls whether or not you are warned by php when initializing a
 ; session value into the global space. session.bug_compat_42 must be enabled before
 ; these warnings can be issued by php. See the directive above for more information.
 ; Default Value: On
 ; Development Value: On
 ; Production Value: Off
 ; http://php.NET/session.bug-compat-warn
 session.bug_compat_warn = Off
; Check HTTP Referer to invalidate externally stored URLs containing ids.
 ; HTTP_REFERER has to contain this substring for the session to be
 ; considered as valid.
 ; http://php.NET/session.referer-check
 session.referer_check =
; How many bytes to read from the file.
 ; http://php.NET/session.entropy-length
 session.entropy_length = 0
; Specified here to create the session id.
 ; http://php.NET/session.entropy-file
 ; On systems that don't have /dev/urandom /dev/arandom can be used
 ; On windows, setting the entropy_length setting will activate the
 ; Windows random source (using the CryptoAPI)
 ;session.entropy_file = /dev/urandom
; Set to {nocache,private,public,} to determine HTTP caching ASPects
 ; or leave this empty to avoid sending anti-caching headers.
 ; http://php.NET/session.cache-limiter
 session.cache_limiter = nocache
; Document expires after n minutes.
 ; http://php.NET/session.cache-expire
 session.cache_expire = 180
; trans sid support is disabled by default.
 ; Use of trans sid may risk your users security.
 ; Use this option with caution.
 ; - User may send URL contains active session ID
 ;   to other person via. email/irc/etc.
 ; - URL that contains active session ID may be stored
 ;   in publically accessible computer.
 ; - User may access your site with the same session ID
 ;   always using URL stored in browser's history or bookmarks.
 ; http://php.NET/session.use-trans-sid
 session.use_trans_sid = 0
; Select a hash function for use in generating session ids.
 ; Possible Values
 ;   0  (MD5 128 bits)
 ;   1  (SHA-1 160 bits)
 ; This option may also be set to the name of any hash function supported by
 ; the hash extension. A list of available hashes is returned by the hash_algos()
 ; function.
 ; http://php.NET/session.hash-function
 session.hash_function = 0
; Define how many bits are stored in each character when converting
 ; the binary hash data to something readable.
 ; Possible values:
 ;   4  (4 bits: 0-9, a-f)
 ;   5  (5 bits: 0-9, a-v)
 ;   6  (6 bits: 0-9, a-z, A-Z, "-", ",")
 ; Default Value: 4
 ; Development Value: 5
 ; Production Value: 5
 ; http://php.NET/session.hash-bits-per-character
 session.hash_bits_per_character = 5
; The URL rewriter will look for URLs in a defined set of HTML tags.
 ; form/fieldset are special; if you include them here, the rewriter will
 ; add a hidden <input> field with the info which is otherwise appended
 ; to URLs.  If you want XHTML conformity, remove the form entry.
 ; Note that all valid entries require a "=", even if no value follows.
 ; Default Value: "a=href,area=href,frame=src,form=,fieldset="
 ; Development Value: "a=href,area=href,frame=src,input=src,form=fakeentry"
 ; Production Value: "a=href,area=href,frame=src,input=src,form=fakeentry"
 ; http://php.NET/url-rewriter.tags
 url_rewriter.tags = "a=href,area=href,frame=src,input=src,form=fakeentry"

因?yàn)檫@個(gè)是在一臺(tái)VPS上面配置的,上面有多個(gè)項(xiàng)目,于是小編打開一個(gè)項(xiàng)目,發(fā)現(xiàn)此項(xiàng)目的驗(yàn)證碼功能是OK的。
于是查看代碼如下:
復(fù)制代碼 代碼如下:
$sessSavePath = "/data/sessions/";
 // Session保存路徑
 if(is_writeable($sessSavePath) && is_readable($sessSavePath)){ session_save_path($sessSavePath); }
 if(!empty($cfg_domain_cookie)) session_set_cookie_params(0,'/',$cfg_domain_cookie);

上面這個(gè)代碼是在session_start() 初始化之前來判斷是否存在session會(huì)話的文件夾。
于是就在phpmyadmin里面的保存的那個(gè)文件/phpmyadmin/libraries/session.inc.php做了下修改:
復(fù)制代碼 代碼如下:
if (! isset($_COOKIE[$session_name])) {
 // on first start of session we check for errors
 // f.e. session dir cannot be accessed - session file not created
 $orig_error_count = $GLOBALS['error_handler']->countErrors();
 //session_save_path('./tmp');
 session_save_path("/data/www/session");
 $r = session_start();
 if ($r !== true
 || $orig_error_count != $GLOBALS['error_handler']->countErrors()
 ) {
 setcookie($session_name, '', 1);
 /*
 * Session initialization is done before selecting language, so we
 * can not use translations here.
 */
 PMA_fatalError('Cannot start session without errors, please check errors given in your php and/or webserver log file and configure your php installation properly. Also ensure that cookies are enabled in your browser.');
 }
 unset($orig_error_count);
 } else {
 session_save_path("/data/www/session");
 session_start();
 }

在 session_start();  前面添加了  session_save_path(“/data/www/session”); 就解決了這個(gè)問題。
切記通過@ini_set(‘session.save_path', ”/data/www/session”);無效!
這個(gè)問題困擾了我?guī)讉€(gè)小時(shí),終于解決了,所以就記錄下來,對(duì)日后應(yīng)該會(huì)有幫助。

php技術(shù)Fatal error: session_start(): Failed to initialize storage module: files問題解決方法,轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 国产乱子伦 | 狼人久草| 成人情趣视频无遮掩免费 | 欧美色视频网 | 精品国产日韩亚洲一区二区 | 久久不射网 | 国产伦精品一区二区三区免费迷 | 免费国产叼嘿视频在线观看 | 激情网址在线观看 | 国产午夜成人无码免费看 | 国产亚洲婷婷香蕉久久精品 | 一本之道无吗一二三区 | 久久噜噜噜久久亚洲va久 | 国产原创麻豆 | 国产乱理论片在线观看理论 | 激情六月丁香婷婷四房播 | 久久久久久久久久福利 | 久久怡红院国产精品 | 黄污视频网站 | 国产精品成人久久久 | 国产精品福利在线观看 | 国产日韩欧美综合一区二区三区 | 国产一二三 | 国产视频第一页 | 看黄视频在线观看 | 中文有码中文字幕免费视频 | 国产视频一区在线播放 | 一道精品视频一区二区三区男同 | 九九热伊人 | 97人人澡人人爽人人爱 | 精品国产福利 | 精品久久一 | 亚洲精品第一 | 日韩美女毛片 | 欧美久草 | 成人黄网大全在线观看 | 亚洲最大免费视频网 | 亚洲欧美一区二区三区四区 | 99精品视频在线观看re | 一区二区在线免费观看 | 国产精品一级片 |