將Session寫入資料庫
使用session_set_save_handler()函數,將Session的內容寫入資料庫
<span> 1</span> <?<span>php </span><span> 2</span> <span>/*</span> <span> 3</span> <span> *@author Fahy </span><span> 4</span> <span> *@link http://home.cnblogs.com/u/HuangWj </span><span> 5</span> <span> *数据库为mysql, </span><span> 6</span> <span> *数据库名为session,表名为session, </span><span> 7</span> <span> *表中字段包括PHPSESSID,update_time,client_ip,data </span><span> 8</span> <span>*/</span> <span> 9</span> <span>class</span><span> Session{ </span><span> 10</span> <span>private</span> <span>static</span> <span>$handler</span> = <span>null</span><span>; </span><span> 11</span> <span>private</span> <span>static</span> <span>$ip</span> = <span>null</span><span>; </span><span> 12</span> <span>private</span> <span>static</span> <span>$lifetime</span> = <span>null</span><span>; </span><span> 13</span> <span>private</span> <span>static</span> <span>$time</span> = <span>null</span><span>; </span><span> 14</span> <span> 15</span> <span>//</span><span>配置静态变量</span> <span> 16</span> <span>private</span> <span>static</span> <span>function</span> init(<span>$handler</span><span>){ </span><span> 17</span> self::<span>$handler</span> = <span>$handler</span>; <span>//</span><span>获取数据库资源</span> <span> 18</span> self::<span>$ip</span> = !<span>empty</span>(<span>$_SERVER</span>["REMOTE_ADDR"])? <span>$_SERVER</span>["REMOTE_ADDR"]:'unkonw'; <span>//</span><span>获取客户端ip</span> <span> 19</span> self::<span>$lifetime</span> = <span>ini_get</span>('session.gc_maxlifetime'); <span>//</span><span>获取session生命周期</span> <span> 20</span> self::<span>$time</span> = <span>time</span>(); <span>//</span><span>获取当前时间</span> <span> 21</span> <span> } </span><span> 22</span> <span>//</span><span>调用session_set_save_handler()函数并开启session</span> <span> 23</span> <span>static</span> <span>function</span> start(<span>$pdo</span><span>){ </span><span> 24</span> self::init(<span>$pdo</span><span>); </span><span> 25</span> <span>session_set_save_handler</span><span>( </span><span> 26</span> <span>array</span>(<span>__CLASS__</span>,'open'), <span> 27</span> <span>array</span>(<span>__CLASS__</span>,'close'), <span> 28</span> <span>array</span>(<span>__CLASS__</span>,'read'), <span> 29</span> <span>array</span>(<span>__CLASS__</span>,'write'), <span> 30</span> <span>array</span>(<span>__CLASS__</span>,'destroy'), <span> 31</span> <span>array</span>(<span>__CLASS__</span>,'gc'<span>) </span><span> 32</span> <span> ); </span><span> 33</span> <span>session_start</span><span>(); </span><span> 34</span> <span> } </span><span> 35</span> <span> 36</span> <span>public</span> <span>static</span> <span>function</span> open(<span>$path</span>,<span>$name</span><span>){ </span><span> 37</span> <span>return</span> <span>true</span><span>; </span><span> 38</span> <span> } </span><span> 39</span> <span>public</span> <span>static</span> <span>function</span><span> close(){ </span><span> 40</span> <span>return</span> <span>true</span><span>; </span><span> 41</span> <span> } </span><span> 42</span> <span> 43</span> <span>//</span><span>查询数据库中的数据</span> <span> 44</span> <span>public</span> <span>static</span> <span>function</span> read(<span>$PHPSESSID</span><span>){ </span><span> 45</span> <span>$sql</span> = "select PHPSESSID,update_time,client_ip,data from session where PHPSESSID=?"<span>; </span><span> 46</span> <span>$stmt</span> = self::<span>$handler</span>->prepare(<span>$sql</span><span>); </span><span> 47</span> <span>$stmt</span>->execute(<span>array</span>(<span>$PHPSESSID</span><span>)); </span><span> 48</span> <span>if</span>(!<span>$result</span> = <span>$stmt</span>->fetch(PDO::<span>FETCH_ASSOC)){ </span><span> 49</span> <span>return</span> ''<span>; </span><span> 50</span> <span> } </span><span> 51</span> <span>if</span>(self::<span>$ip</span> == <span>$result</span>['client_ip'<span>]){ </span><span> 52</span> self::destroy(<span>$PHPSESSID</span><span>); </span><span> 53</span> <span>return</span> ''<span>; </span><span> 54</span> <span> } </span><span> 55</span> <span>if</span>((<span>$result</span>['update_time']+self::<span>$lifetime</span>)<self::<span>$time</span><span>){ </span><span> 56</span> self::destroy(<span>$PHPSESSID</span><span>); </span><span> 57</span> <span>return</span> ''<span>; </span><span> 58</span> <span> } </span><span> 59</span> <span>return</span> <span>$result</span>['data'<span>]; </span><span> 60</span> <span> } </span><span> 61</span> <span>/*</span> <span> 62</span> <span> *首先查询该session是否存在数据,如果存在,则更新数据,如果不存在,则插入数据 </span><span> 63</span> <span>*/</span> <span> 64</span> <span>//</span><span>将session写入数据库中,$data传入session中的keys和values数组</span> <span> 65</span> <span>public</span> <span>static</span> <span>function</span> write(<span>$PHPSESSID</span>,<span>$data</span><span>){ </span><span> 66</span> <span>$sql</span> = "select PHPSESSID,update_time,client_ip,data from session where PHPSESSID=?"<span>; </span><span> 67</span> <span>$stmt</span> = self::<span>$handler</span>->prepare(<span>$sql</span><span>); </span><span> 68</span> <span>$stmt</span>->execute(<span>array</span>(<span>$PHPSESSID</span><span>)); </span><span> 69</span> <span> 70</span> <span>if</span>(<span>$result</span>=<span>$stmt</span>->fetch(PDO::<span>FETCH_ASSOC)){ </span><span> 71</span> <span>if</span>(<span>$result</span>['data'] != <span>$data</span> || self::<span>$time</span> > (<span>$result</span>['update_time']+30<span>)){ </span><span> 72</span> <span>$sql</span> = "update session set update_time=?,data=? where PHPSESSID = ?"<span>; </span><span> 73</span> <span>$stmt</span> = self::<span>$handler</span>->prepare(<span>$sql</span><span>); </span><span> 74</span> <span>$stmt</span>->execute(<span>array</span>(<span>$self</span>::<span>$time</span>,<span>$data</span>,<span>$PHPSESSID</span><span>)); </span><span> 75</span> <span> } </span><span> 76</span> }<span>else</span><span>{ </span><span> 77</span> <span>if</span>(!<span>empty</span>(<span>$data</span><span>)){ </span><span> 78</span> <span>try</span><span>{ </span><span> 79</span> <span>$sql</span> = "insert into session(PHPSESSID,update_time,client_ip,data) values(?,?,?,?)"<span>; </span><span> 80</span> }<span>catch</span>(PDOException <span>$e</span><span>){ </span><span> 81</span> <span>echo</span> <span>$e</span>-><span>getMessage(); </span><span> 82</span> <span> } </span><span> 83</span> <span>$sth</span> = self::<span>$handler</span>->prepare(<span>$sql</span><span>); </span><span> 84</span> <span>$sth</span>->execute(<span>array</span>(<span>$PHPSESSID</span>,self::<span>$time</span>,self::<span>$ip</span>,<span>$data</span><span>)); </span><span> 85</span> <span> } </span><span> 86</span> <span> } </span><span> 87</span> <span>return</span> <span>true</span><span>; </span><span> 88</span> <span> } </span><span> 89</span> <span> 90</span> <span>public</span> <span>static</span> <span>function</span> destroy(<span>$PHPSESSID</span><span>){ </span><span> 91</span> <span>$sql</span> = "delete from session where PHPSESSID = ?"<span>; </span><span> 92</span> <span>$stmt</span> = self::<span>$handler</span>->prepare(<span>$sql</span><span>); </span><span> 93</span> <span>$stmt</span>->execute(<span>array</span>(<span>$PHPSESSID</span><span>)); </span><span> 94</span> <span>return</span> <span>true</span><span>; </span><span> 95</span> <span> } </span><span> 96</span> <span>public</span> <span>static</span> <span>function</span> gc(<span>$lifetime</span><span>){ </span><span> 97</span> <span>$sql</span> = "delete from session where update_time<?"<span>; </span><span> 98</span> <span>$stmt</span> = self::<span>$handler</span>->prepare(<span>$sql</span><span>); </span><span> 99</span> <span>$stmt</span>->execute(<span>array</span>(self::<span>$time</span>-<span>$lifetime</span><span>)); </span><span>100</span> <span>return</span> <span>true</span><span>; </span><span>101</span> <span> } </span><span>102</span> <span> } </span><span>103</span> <span>//</span><span>使用PDO连接数据库</span> <span>104</span> <span>try</span><span>{ </span><span>105</span> <span>$pdo</span> = <span>new</span> PDO("mysql:host=localhost;dbname=session","root","hwj193"<span>); </span><span>106</span> }<span>catch</span>(PDOException <span>$e</span><span>){ </span><span>107</span> <span>echo</span> <span>$e</span>-><span>getMessage(); </span><span>108</span> <span> } </span><span>109</span> <span>//</span><span>传递数据库资源</span> <span>110</span> Session::start(<span>$pdo</span>);
以上就介紹了將Session寫入資料庫,包括了方面的內容,希望對PHP教程有興趣的朋友有所幫助。

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

報錯的原因NameResolutionError(self.host,self,e)frome是由urllib3函式庫中的例外類型,這個錯誤的原因是DNS解析失敗,也就是說,試圖解析的主機名稱或IP位址無法找到。這可能是由於輸入的URL位址不正確,或DNS伺服器暫時無法使用所導致的。如何解決解決此錯誤的方法可能有以下幾種:檢查輸入的URL地址是否正確,確保它是可訪問的確保DNS伺服器可用,您可以嘗試在命令行中使用"ping"命令來測試DNS伺服器是否可用嘗試使用IP位址而不是主機名稱來存取網站如果是在代理

php session刷新後沒有了的解決方法:1、透過「session_start();」開啟session;2、把所有的公共配置寫在一個php檔案內;3、變數名稱不能和陣列下標相同;4、在phpinfo裡面查看session資料的儲存路徑,並查看該檔案目錄下的sessio是否儲存成功即可。

問題發現springboot專案生產session-out逾時問題,描述下問題:在測試環境透過改動application.yaml配置session-out,經過設定不同時間驗證session-out配置生效,於是就直接設定了過期時間為8小時發布到了生產環境。然而中午接到客戶反應項目過期時間設定較短,半小時不操作就會話過期需要重複登陸。解決處理開發環境:springboot專案內建Tomcat,所以專案中application.yaml配置session-out是生效的。生產環境:生產環境發布是

session失效通常是由於 session 的生存時間過期或伺服器關閉導致的。其解決方法:1、延長session的生存時間;2、使用持久化儲存;3、使用cookie;4、非同步更新session;5、使用會話管理中介軟體。

問題:今天專案中遇到了一個設定時間逾時的問題,按SpringBoot2的application.properties變更一直不生效。解決方案:server.*屬性用於控制SpringBoot所使用的嵌入式容器。 SpringBoot將使用ServletWebServerFactory實例之一來建立servlet容器的執行個體。這些類別使用server.*屬性來配置受控的servlet容器(tomcat,jetty等)。當應用程式作為war檔部署到Tomcat實例時,server.*屬性不適用。它們不適用,

PHPSession跨域問題的解決方法在前後端分離的開發中,跨域請求已成為常態。在處理跨域問題時,我們通常會涉及session的使用和管理。然而,由於瀏覽器的同源策略限制,跨域情況下預設無法共享session。為了解決這個問題,我們需要採用一些技巧和方法來實現session的跨域共享。一、使用cookie跨域共享session最常

session php預設失效時間是1440秒,也就是24分鐘,表示客戶端超過24分鐘沒有刷新,當前session就會失效;如果使用者關閉了瀏覽器,會話就會結束,Session就不存在了。

1.基於session實作簡訊登入1.1簡訊登入流程圖1.2實作發送簡訊驗證碼前端請求說明:說明請求方式POST請求路徑/user/code請求參數phone(電話號碼)回傳值無後端介面實作:@Slf4j@ ServicepublicclassUserServiceImplextendsServiceImplimplementsIUserService{@OverridepublicResultsendCode(Stringphone,HttpSessionsession){//1.校驗手機號碼if
