PHP에서 토큰을 설정하는 방법
PHP에서 토큰을 설정하는 방법: 먼저 토큰을 얻기 위한 라우팅 경로를 정의한 다음 서비스 계층을 설정하고 모델 계층에서 사용자 클래스를 생성하고 유효성 검사기 클래스 및 예외 클래스에서 해당 확인 방법과 예외 처리를 생성합니다. ; 최종적으로 토큰을 완성합니다. 토큰을 작성하면 됩니다.
권장: "PHP 비디오 튜토리얼"
우리가 개발한 백엔드 API 인터페이스에는 방문자에 대한 권한 요구 사항이 있습니다. 예를 들어 개인 정보가 포함된 일부 인터페이스에서는 방문자가 동시에 인터페이스를 요청해야 합니다. 미리 발급받은 Token을 방문자에게 전달합니다.
이것은 토큰과 같습니다. 방문자가 이를 보여줄 경우에만 방문자를 "통과"합니다.
다음은 권한 토큰에 대한 코드 작성 아이디어에 대한 기록입니다.
1. 프로세스 개요
토큰을 얻기 위한 라우팅 경로를 정의하고 코드 매개변수를 수락합니다. (코드 소스: WeChat 서버, 로그인 시스템은 WeChat 시스템 기반)
서비스 레이어를 구축하고 토큰 기반을 생성합니다. 이 레이어의 클래스와 UserToken 클래스
UserToken 클래스는 전체 로직을 처리합니다: 토큰 생성 및 반환
사용자 데이터 테이블을 읽고 쓰는 일을 담당하고 UserToken에서 호출할 수 있는 User 클래스를 모델 레이어에 설정합니다. 서비스 레이어
validator 클래스와 예외 클래스에서 해당 검증 메서드와 예외를 생성합니다. 프로세싱
컨트롤러->서비스 레이어->모델 레이어가 서비스 레이어에 값을 반환->서비스 레이어가 전체 값을 컨트롤러에 반환합니다. 프로세스는 토큰 토큰 작성을 완료합니다
2. 특정 지침
먼저 라우팅 경로를 정의합니다.
Route::post( 'api/:version/token/user', 'api/:version.Token/getToken');
그런 다음 토큰 컨트롤러를 만들고 라우팅 경로에 해당하는 getToken 메서드를 정의합니다.
public function getToken($code='') { (new TokenGet())->goCheck($code); // 验证器 $token = (new UserToken($code))->get(); return [ 'token' => $token ]; }
서비스 계층을 호출하기 전에 전달된 매개변수를 확인해야 하므로 TokenGet 유효성 검사기를 정의합니다.
class TokenGet extends BaseValidate { protected $rule = [ 'code' => 'require|isNotEmpty' ]; protected $message = [ 'code' => '需要code才能获得Token!' ]; }
토큰 컨트롤러로 돌아가서 확인을 통과한 후 서비스 계층에서 정의한 UserToken 클래스를 호출합니다.
$token = (new UserToken($code))->get();
여기에서는 서비스 계층과 모델 계층에 대해 설명합니다. 우리의 일반적인 이해는 서비스 계층이 모델 계층을 기반으로 하는 추상 캡슐화라는 것입니다.
모델 레이어는 데이터베이스를 운영하고 이를 서비스 레이어로 반환하는 역할만 담당합니다
그런 다음 서비스 레이어는 비즈니스 로직을 처리하고 마지막으로 이를 컨트롤러 레이어로 반환합니다
하지만 소규모 프로젝트의 경우 서비스는 실제로 일부 간단한 인터페이스 모델 레이어는 컨트롤러에 직접 연결될 수 있기 때문에 사용자 권한과 같은 상대적으로 복잡한 인터페이스만 서비스 레이어를 통해 다양한 기능에 대한 코드로 분리될 수 있습니다.
이런 종류의 처리는 더 유연합니다. 정말 간단한 인터페이스가 많으면 서비스 계층을 한 번 거치지 않아도 됩니다. 이는 동작을 수행하는 것과 비슷하며 의미가 없습니다.
서비스 계층의 코드 작성으로 돌아가서 다양한 유형의 토큰이 있으므로 먼저 몇 가지 공통 메서드가 포함된 토큰 기본 클래스를 만듭니다. 그런 다음 방문자에게 토큰을 반환하는 UserToken 클래스가 준비됩니다.
WeChat을 기반으로 하기 때문에 code, appid, appsecret의 세 가지 정보가 필요하며 생성자를 통해 UserToken 클래스에 초기 값을 할당합니다.
function __construct($code) { $this->code = $code; $this->wxAppID = config('wx.app_id'); $this->wxAppSecret = config('wx.app_secret'); $this->wxLoginUrl = sprintf( config('wx.login_url'), $this->wxAppID, $this->wxAppSecret, $this->code ); }
그런 다음 이 세 가지 정보를 인터페이스의 매개변수 위치에 넣습니다. WeChat에서 제공하는 목적은 완전한 WeChat 서버 측 URL을 얻고 필요한 openid를 요청하는 것입니다.
그런 다음 여기에서는 네트워크 요청을 보내는 단계를 건너뜁니다. WeChat 서버는 openid가 포함된 객체를 반환합니다. 이 객체의 값이 괜찮다고 판단한 후, grantToken() 함수를 생성합니다.
private function grantToken($openidObj) { // 取出openid $openid = $openidObj['openid']; // 通过Model层调用数据库,检查openid是否已经存在 $user = UserModel::getByOpenID($openid); // 如果存在,不处理,反之则新增一条user记录 if ($user) { $uid = $user->id; } else { // 不存在,生成一条数据,具体方法略过 $uid = $this->newUser($openid); } // 生成令牌,写入缓存(具体方法见下面的定义) $cachedValue = $this->prepareCacheValue($openidObj, $uid); $token = $this->saveToCache($cachedValue); // 令牌返回到调用者端 return $token; } private function prepareCacheValue($openidObj, $uid) { $cachedValue = $openidObj; $cachedValue['uid'] = $uid; $cachedValue['scope'] = 16; // 权限值,自己定义 return $cachedValue; } private function saveToCache($cachedValue) { $key = self::generateToken(); // 生成令牌的方法 $value = json_encode($cachedValue); $tokenExpire = config('setting.token_expire'); // 设定的过期时间 $request = cache($key, $value, $tokenExpire); if (!$request) { throw new TokenException([ 'msg' => '服务器缓存异常', 'errorCode' => 10005 ]); } return $key; // 返回令牌:token }
보시다시피 핵심 프로세스는 다음과 같습니다.
openid 가져오기
데이터베이스를 확인하고 openid가 이미 존재하는지 확인하세요
존재하는 경우 처리하지 말고, 그렇지 않으면 새 사용자 레코드를 추가하세요.
토큰 생성, 캐시 데이터 준비, 캐시에 쓰기
토큰 반환 to the client
generateToken() 메소드는 다음과 같이 자세히 정의됩니다:
public static function generateToken() { $randomChars = getRandomChars(32); // 32个字符组成一组随机字符串 $timestamp = $_SERVER['REQUEST_TIME_FLOAT']; $salt = config('security.token_salt'); // salt 盐 // 拼接三组字符串,进行MD5加密,然后返回 return md5($randomChars.$timestamp.$salt); } function getRandomChars($length) { $str = null; $strPoll = 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789'; $max = strlen($strPoll) - 1; for ($i = 0; $i < $length; $i++) { $str .= $strPoll[rand(0, $max)]; } return $str; }
이 메소드의 주요 기능은 의심할 여지 없이 우리에게 필요한 토큰인 토큰 문자열을 생성하는 것입니다. generateToken()은 다른 유형의 토큰에도 사용되므로 Token 기본 클래스에 배치된다는 점을 언급할 가치가 있습니다.
이 시점에서는 생성된 토큰만 컨트롤러에 반환하면 됩니다.
3. 요약
토큰 작성에는 많은 프로세스가 필요합니다. 혼란을 피하기 위해 다양한 방법으로 다양한 작업을 담당하는 코드를 정의해야 합니다. 위 예제의 grantToken() 메소드와 같이 모든 프로세스를 포함하는 핵심 메소드이지만, 다른 특정 프로세스는 다른 메소드에 정의되어 grantToken() 메소드 호출에 제공됩니다.
이 작업을 수행한 후에도 모든 프로세스가 포함되어 있음에도 grantToken() 메서드는 여전히 읽기 쉽습니다.
위 내용은 PHP에서 토큰을 설정하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

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

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

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

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

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

유효하지 않은 로그인 토큰에 대한 해결 방법에는 토큰 만료 여부 확인, 토큰이 올바른지 확인, 토큰 변조 여부 확인, 토큰이 사용자와 일치하는지 확인, 캐시 또는 쿠키 지우기, 네트워크 연결 및 서버 상태 확인이 포함됩니다. , 다시 로그인하거나 새로운 토큰을 요청하려면 기술 지원팀이나 개발자에게 문의하세요. 자세한 소개: 1. 토큰이 만료되었는지 확인하세요. 일반적으로 로그인 토큰에는 유효 기간이 설정되어 있습니다. 유효 기간이 초과되면 유효하지 않은 것으로 간주됩니다.

유효하지 않은 로그인 토큰 문제는 네트워크 연결 확인, 토큰 유효 기간 확인, 캐시 및 쿠키 삭제, 로그인 상태 확인, 애플리케이션 개발자 문의 및 계정 보안 강화를 통해 해결할 수 있습니다. 자세한 소개: 1. 네트워크 연결을 확인하고 네트워크에 다시 연결하거나 네트워크 환경을 변경합니다. 2. 토큰 유효 기간을 확인하고 새 토큰을 얻거나 애플리케이션 개발자에게 문의합니다. 3. 캐시 및 쿠키를 지우고 브라우저를 지웁니다. 캐시 및 쿠키를 확인한 후 다시 애플리케이션에 로그인하세요. 4. 로그인 상태를 확인하세요.

Redis는 사용자 토큰을 저장합니다. 전자 상거래와 유사한 시스템을 설계할 때 일반적인 요구 사항은 각 페이지에 로그인된 사용자 정보를 전달해야 한다는 것입니다. 두 가지 일반적인 솔루션이 있습니다. 쿠키를 사용하여 저장하는 것과 JWT를 사용하여 저장하는 것입니다. 그러나 Redis 캐시가 시스템에서 사용되는 경우 Redis에서 사용자 토큰을 캐싱하는 세 번째 솔루션도 있습니다. 로그인 시 토큰을 생성하여 Redis에 저장 //토큰 객체를 생성하여 redis에 저장 redisTemplate.opsForHash().put("token","user",user)

C++ 구문 오류: 'expectedprimary-expressionbefore':'token'을 해결하는 방법은 무엇입니까? 구문 오류는 C++ 프로그래밍에서 흔히 발생하는 문제입니다. 일반적인 오류 중 하나는 "expectedprimary-expressionbefore':'token" 오류 메시지입니다. 이 오류는 일반적으로 조건식과 삼항 연산자를 사용할 때 발생합니다. 이 기사에서는 이 오류의 원인을 소개합니다.

1. 토큰 로그인 인증 jwt: JSONWebToken. 요청된 신원 정보와 신원 권한을 확인하기 위해 일반적으로 사용되는 인증 프로토콜입니다. Header, Hayload, Signatureheader의 세 부분으로 구성됩니다. 즉, 이 토큰을 설명하는 기본 정보인 헤더 정보, json 형식 {"alg":"HS256", //서명 알고리즘을 나타냅니다. 기본값은 HMACSHA256( HS256으로 작성) "type":"JWT"//JWT 토큰의 유형을 JWT}pa로 일률적으로 작성함을 나타냅니다.

의외로 ChatGPT가 오늘날에도 여전히 어리석은 실수를 저지르고 있을까요? Master Ng Enda는 최신 수업에서 다음과 같이 지적했습니다. ChatGPT는 단어를 뒤집지 않습니다! 예를 들어, Lollipop이라는 단어를 거꾸로 하면 완전히 혼란스러운 pilollol이 출력됩니다. 아, 이건 좀 놀랍네요. 그만큼 수업을 들은 한 네티즌이 레딧에 글을 올리자 곧바로 많은 누리꾼들이 몰리며 조회수는 단숨에 6천회에 이르렀다. 그리고 이것은 우연한 버그가 아닙니다. 네티즌들은 ChatGPT가 실제로 이 작업을 완료할 수 없다는 것을 발견했으며 개인 테스트 결과에서도 마찬가지입니다. △ChatGPT(GPT-3.5)와 Bard, Bing, Wen Xinyiyan 등 많은 제품의 실제 테스트가 작동하지 않습니다. △실제 테스트 바드 △실제 테스트 원신이옌

토큰은 가상 화폐의 일종으로, 사용자 권한을 표시하고 거래 정보를 기록하며 가상 화폐를 지불하는 데 사용되는 디지털 화폐입니다. 토큰은 특정 네트워크에서 거래를 수행하는 데 사용될 수 있고, 특정 가상 화폐를 사고 파는 데 사용될 수 있으며, 특정 서비스에 대한 비용을 지불하는 데에도 사용될 수 있습니다.

1. ThinkPhp 프레임워크에서 토큰 사용 1. 먼저 데이터베이스의 사용자 테이블에 두 개의 필드 token 및 time_outtoken을 추가하여 사용자 토큰을 저장합니다. time_out은 사용자 토큰의 만료 시간을 설정하는 데 사용됩니다. 2. checkToekn( $token) 함수는 토큰이 존재하는지 확인하고 토큰을 업데이트합니다. publicfunctioncheckToken($token){$user=new\app\index\model\Users();
