데이터베이스에 세션 쓰기
session_set_save_handler() 함수를 사용하여 세션 내용을 데이터베이스에 씁니다
<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>);
위 내용은 관련 측면을 포함하여 데이터베이스에 세션을 작성하는 방법을 소개합니다. PHP 튜토리얼에 관심이 있는 친구들에게 도움이 되기를 바랍니다.

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











springboot 프로젝트 프로덕션 세션아웃 시간 초과에서 문제가 발견되었습니다. 문제 설명: 테스트 환경에서는 세션아웃 구성이 적용되었는지 확인하기 위해 application.yaml을 변경하여 세션아웃을 구성했습니다. , 프로덕션 환경에 도착하면 만료 시간이 8시간으로 직접 설정되었습니다. 그런데 정오에 고객으로부터 프로젝트 만료 시간이 짧게 설정되어 있다는 피드백을 받았습니다. 30분 동안 아무 작업도 수행하지 않으면 세션이 만료되어 반복 로그인이 필요합니다. 개발 환경 처리 문제를 해결합니다. springboot 프로젝트에는 Tomcat이 내장되어 있으므로 프로젝트의 application.yaml에 구성된 세션 아웃이 효과적입니다. 프로덕션 환경: 프로덕션 환경 릴리스는 다음과 같습니다.

세션 실패는 일반적으로 세션 수명 만료 또는 서버 종료로 인해 발생합니다. 해결 방법은 다음과 같습니다. 1. 세션 수명을 연장합니다. 3. 쿠키를 사용합니다. 4. 세션 관리 미들웨어를 사용합니다.

오류의 원인은 urllib3 라이브러리의 예외 유형인 NameResolutionError(self.host,self,e)frome입니다. 이 오류의 원인은 DNS 확인에 실패했기 때문입니다. 해결을 찾을 수 없습니다. 이는 입력한 URL 주소가 정확하지 않거나 DNS 서버를 일시적으로 사용할 수 없기 때문에 발생할 수 있습니다. 이 오류를 해결하는 방법 이 오류를 해결하는 방법은 여러 가지가 있습니다. 입력한 URL 주소가 올바른지 확인하고 액세스할 수 있는지 확인하십시오. DNS 서버를 사용할 수 있는지 확인하십시오. 명령줄에서 "ping" 명령을 사용해 볼 수 있습니다. DNS 서버를 사용할 수 있는지 테스트하려면 프록시 뒤에 있는 경우 호스트 이름 대신 IP 주소를 사용하여 웹사이트에 액세스해 보세요.

PHPSession의 도메인 간 문제 해결 프런트엔드와 백엔드 분리 개발에서 도메인 간 요청이 표준이 되었습니다. 도메인 간 문제를 처리할 때 일반적으로 세션 사용 및 관리가 포함됩니다. 그러나 브라우저 원본 정책 제한으로 인해 기본적으로 도메인 간에 세션을 공유할 수 없습니다. 이 문제를 해결하려면 도메인 간 세션 공유를 달성하기 위한 몇 가지 기술과 방법을 사용해야 합니다. 1. 도메인 간 세션을 공유하기 위한 쿠키의 가장 일반적인 사용

새로 고침 후 PHP 세션이 사라지는 문제에 대한 해결 방법: 1. "session_start();"를 통해 세션을 엽니다. 2. 모든 공개 구성을 PHP 파일에 작성합니다. 3. 변수 이름은 배열 첨자와 같을 수 없습니다. 4. phpinfo에서 세션 데이터의 저장 경로를 확인하고 파일 디렉터리의 sessio가 성공적으로 저장되었는지 확인합니다.

세션 PHP의 기본 만료 시간은 1440초(24분)입니다. 즉, 클라이언트가 24분 이상 새로 고치지 않으면 사용자가 브라우저를 닫으면 현재 세션이 만료되고 세션이 종료됩니다. 세션이 더 이상 존재하지 않습니다.

오늘은 golang time 패키지의 시간 적용 방법을 주로 살펴보겠습니다. 둘 사이의 일반적인 규칙은 "벽 시간"이 시간을 알려주는 데 사용되고 "단조 시계"가 시간을 측정하는 데 사용된다는 것입니다. 다른 시계 처리 방법이 있습니다.

문제: 오늘 프로젝트에서 설정 시간 초과 문제가 발생했으며 SpringBoot2의 application.properties에 대한 변경 사항이 적용되지 않았습니다. 해결 방법: server.* 속성은 SpringBoot에서 사용하는 내장 컨테이너를 제어하는 데 사용됩니다. SpringBoot는 ServletWebServerFactory 인스턴스 중 하나를 사용하여 서블릿 컨테이너의 인스턴스를 생성합니다. 이러한 클래스는 server.* 속성을 사용하여 제어되는 서블릿 컨테이너(tomcat, jetty 등)를 구성합니다. 애플리케이션이 Tomcat 인스턴스에 war 파일로 배포되면 server.* 속성이 적용되지 않습니다. 적용되지 않습니다.
