이 문서의 내용은 PHP Basics 8의 세션 관리 및 제어에 관한 것입니다. 이제 특정 참조 가치가 있습니다. 필요한 친구가 참조할 수 있습니다.
<!-- 第十四章 php会话管理和控制 --> <?php setcookie('name'); setcookie('mycookie'); setcookie('mycookie',''); setcookie("mycookie",false); setcookie('mycookie','',time()-3600); echo ($HTTP_COOKIE_VARS['mycookie']); print_r($_COOKIE); ?> <?php if (($_POST['username'] != null) && ($_POST['password'] != null)) { $userName = $_POST['username']; $passWord =md5($_POST['password']); $conn = mysqli_connect('localhost', 'root', 'root'); mysqli_select_db($conn, 'test'); $sql = "select * from user where 'username = '$userName'"; $res = mysqli_query($conn, $sql); $row = mysqli_fetch_assoc($res); if ($row['password'] == $passWord) { setcookie('username',$userName,time()+60*60*24*30); setcookie('password',$passWord,time()+60*60*24*30); header('Location: welcome.php'."?username=$userName"); } } if (($_COOKIE['username'] != null) && ($_COOKIE['password'] != null)) { $userName = $_COOKIE['username']; $passWord = $_COOKIE['password']; $conn = mysqli_connect('localhost', 'root', 'root', 'test'); $res = mysqli_query($conn, "select * from user where username = '$userName'"); $row = mysqli_fetch_assoc($res); if ($row['password'] == $passWord) { header('location:welcome.php'."?username=$userName"); } } ?> <html> <head> </head> <body> <form action="" method="post"> <p> 用户名:<input type="text" name="username" /> 密码:<input type="text" name="password" /> <input type="submit" value="登录"/> </p> </form> </body> </html> <?php /* * session使用: * 1.开启session * 2.添加session * 3.读取session数据 * 4.销毁session数据 * 5.session的扩展:默认session存储位置 */ session_start(); $_SESSION=array('name' => '小明'); $_SESSION = array();//销毁 echo $_SESSION['name']; // $_SESSION['name']='小明'; // $_SESSION['name']='小明1'; // echo $_SESSION['name']; // unset($_SESSION['name']);销毁且不可逆 // echo $_SESSION['name']; ?> <?php session_start(); if (($_POST['username'] != null) && ($_POST['password'] != null)) { $userName = $_POST['username']; $passWord = $_POST['password']; $conn = mysqli_connect('localhost', 'root', 'root', 'test'); $res = mysqli_query($conn, "select * from user where username='$userName'"); $row = mysqli_fetch_assoc($res); if ($row['password'] == $passWord) { $_SESSION['username'] = $userName; $_SESSION['password'] = $passWord; header('Location:welcome.php'); } } ?> <?php session_start(); $userName = $_SESSION['username']; ?> <?php $goods = array(); $i = 0; $conn = mysqli_connect('localhost', 'root', 'root', 'test'); $res = mysqli_query($conn, 'select * from shop'); while ($row = mysqli_fetch_assoc($res)){ $goods[$i]['id'] = $row['id']; $goods[$i]['name'] = $row['name']; $goods[$i]['price'] = $row['price']; $i++; } ?> <html> <head> <meta http-equiv="Content-Type" content="text/html;charset=utf-8"> </head> <body> <?php foreach ($goods as $value){ echo '商品名'.$value['name'].'价格'.$value['price']; echo "<a href=buy.php?name=".$value['name'].'&price='. $value['price'].">购买</a>"; echo '<br />'; } ?> <a href="shoppingCart.php">查看购物车</a> </body> </html> <html> <head> <meta http-equiv="Content-Type" content="text/html;charset=utf-8"> </head> <body> <?php session_start(); $name = $_GET['name']; $price = $_GET['price']; $goods = $_SESSION['goods']; if ($name == $goods[$name]['name']) { $_SESSION['totalPrice'] += $price; $goods[$name]['number'] += 1; }else { $goods[$name]['name'] = $name; $goods[$name]['price'] = $price; $goods[$name]['number'] += 1; $_SESSION['totalPrice'] += $price; } $_SESSION['goods'] = $goods; header('location: goodsList.php'); ?> </body> </html> <html> <head> <meta http-equiv="Content-Type" content="text/html;charset=utf-8"> </head> <body> <?php session_start(); $goods = $_SESSION['goods']; echo '您购买了:<br />'; foreach ($goods as $value){ echo $value['name'].'价格'.$value['price'].'数量'.$value['number'].'<br />'; } echo '总数:'.$_SESSION['totalPrice'].'<br />'; ?> <a href="goodsList.php">返回商品列表</a> </body> </html>
관련 권장 사항:
위 내용은 PHP 기본 8개 세션 관리 및 제어의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

phpsessionscanstorestrings, 숫자, 배열 및 객체 1.Strings : TextDatalikeUsernames.2.numbers : integorfloatsforcounters.3.arrays : listslikeshoppingcarts.4.objects : complexStructuresThatareserialized.

세션 재생은 세션 고정 공격의 경우 사용자가 민감한 작업을 수행 할 때 새 세션 ID를 생성하고 이전 ID를 무효화하는 것을 말합니다. 구현 단계에는 다음이 포함됩니다. 1. 민감한 작업 감지, 2. 새 세션 ID 생성, 3. 오래된 세션 ID 파괴, 4. 사용자 측 세션 정보 업데이트.

PHP 세션은 응용 프로그램 성능에 큰 영향을 미칩니다. 최적화 방법은 다음과 같습니다. 1. 데이터베이스를 사용하여 세션 데이터를 저장하여 응답 속도를 향상시킵니다. 2. 세션 데이터 사용을 줄이고 필요한 정보 만 저장하십시오. 3. 비 차단 세션 프로세서를 사용하여 동시성 기능을 향상시킵니다. 4. 사용자 경험과 서버 부담의 균형을 맞추기 위해 세션 만료 시간을 조정하십시오. 5. 영구 세션을 사용하여 데이터 읽기 및 쓰기 시간의 수를 줄입니다.

phpsessionsareser-side, whilecookiesareclient-side.1) sessions stessoredataontheserver, andhandlargerdata.2) cookiesstoredataonthecure, andlimitedinsize.usesessionsforsensitivestataondcookiesfornon-sensistive, client-sensation.

phpidifiesauser의 sssessionusessessioncookiesandssessionids.1) whensession_start () iscalled, phpgeneratesauniquessessionStoredInacookienamedPhpsSessIdonSeuser 'sbrowser.2) thisidallowsphptoretrievessessionDataTromServer.

PHP 세션의 보안은 다음 측정을 통해 달성 할 수 있습니다. 1. Session_REGENEREAT_ID ()를 사용하여 사용자가 로그인하거나 중요한 작업 일 때 세션 ID를 재생합니다. 2. HTTPS 프로토콜을 통해 전송 세션 ID를 암호화합니다. 3. 세션 _save_path ()를 사용하여 세션 데이터를 저장하고 권한을 올바르게 설정할 보안 디렉토리를 지정하십시오.

phpsessionfilesarestoredInTheRectorySpecifiedBysession.save_path, 일반적으로/tmponunix-likesystemsorc : \ windows \ temponwindows.tocustomizethis : 1) austession_save_path () toSetacustomDirectory, verlyTeCustory-swritation;


핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

SecList
SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.

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

DVWA
DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는

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

MinGW - Windows용 미니멀리스트 GNU
이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.
