앱 인터페이스 토큰에 대한 자세한 설명
1. 먼저 인터페이스가 무엇인지 이야기해 보겠습니다. 간단히 말해서 인터페이스는 서버가 다른 프로그램이나 클라이언트에 데이터를 반환하는 데 사용하는 브리지입니다.
2. 인터페이스의 역할: 고정된 데이터를 고정된 대로 반환합니다. 클라이언트가 a =1을 전달하는 것과 같은 매개변수를 사용하면 서버는 a의 이름을 반환하고 클라이언트는 a=2를 전달하며 서버는 다른 데이터를 반환하지 않고 a의 성별을 반환합니다.
3. 서명의 역할: 인터페이스 및 데이터의 보안을 보장합니다.
4. 토큰의 역할: PC 로그인 세션과 동일하며 사용자 진입을 위한 유일한 티켓입니다.
예: 앱 간 인터페이스 및 서버, java 및 php 서로 다른 프로그램 간의 인터페이스로, 이러한 인터페이스는 일반적으로 json 형식으로 데이터를 전송합니다
따라서 모바일 단말기와 서버 간의 데이터 전송에 대한 상대적인 보안을 보장하기 위해 인터페이스를 암호화하여 전송해야 합니다
1. 토큰의 설계 목적:
APP 측에는 세션 메커니즘이 없고 PC 측에는 동일한 세션 메커니즘이 있으므로 사용자의 로그인 여부를 확인할 수 없으며 사용자 상태를 유지할 수 없으므로 세션을 실현하려면 메커니즘이 필요합니다. 이것이 토큰의 역할입니다. 토큰은 사용자가 로그인할 수 있는 유일한 티켓입니다. 토큰이 APP에서 전송되는 한 서버 측과 일치하므로 이를 증명할 수 있습니다. (영화를 볼 때와 마찬가지로 티켓을 구매해야 하며 티켓으로 입장할 수 있습니다.)
2. 토큰 디자인 유형:
(1) 타사 로그인 유형: 이 유형 토큰의 모양은 WeChat의 access_token과 같습니다. 설계 원칙은 OAuth2.0을 기반으로 합니다. 이는 정기적인 새로 고침(예: 2시간 새로 고침)이 특징입니다. 그 목적은 로그인 권한을 부여할 때 데이터 소스가 유효 기간을 제어해야 하기 때문입니다. 그렇지 않으면 제3자 서버가 사용자의 동의 없이 데이터 원본 서버에서 무기한으로 사용자 데이터를 얻을 수 있습니다.
(2) APP 자체 사용 로그인 유형: 이러한 종류의 토큰이 사용됩니다. 일반 APP의 경우 제3자를 거치지 않고 사용자가 데이터 소스 서버에서 직접 데이터를 얻기 때문에 디자인이 비교적 캐주얼합니다. 3. APP 자체 토큰의 고유성만 확인하면 됩니다. 로그인 토큰 구현 단계 사용:
(1) 데이터베이스 사용자 테이블에 토큰 필드 및 time_out을 추가합니다. 토큰 만료 시간 필드 (2) 사용자가 로그인할 때(등록 중 자동 로그인에도 필요함), 토큰 및 만료 시간
(3) 다른 인터페이스를 호출하기 전에 토큰이 올바른지 확인하고, 잘못된 경우 사용자가 다시 로그인하도록 합니다.
4. 회사 자체 프레임워크 및 논리는 주로 논리에 따라 다르므로 코드를 직접 복사하지 마십시오.):
(1)//下面是用户登陆时把token插入数据库的代码 $logininfo['token'] = appuser::settoken(); $time_out = strtotime("+7 days"); db::setByPk('u_adver', array('token1' => $logininfo['token'], 'time_out' => $time_out), $logininfo['id']); (2)//下面是生成token方法代码 public static function settoken() { $str = md5(uniqid(md5(microtime(true)),true)); //生成一个不会重复的字符串 $str = sha1($str); //加密 return $str; } (3)//下面是每个接口都必须调用的token验证代码,验证具体实现是在(4) $args['token'] = $_POST['token']; $tokencheck = appuser::checktokens($args['token'], 'u_adver'); if ($tokencheck != 90001) { $res['msg_code'] = $tokencheck; v_json($res); } (4)//token验证方法,db::是数据库操作类,这里设置是token如果七天没被调用则需要重新登陆(也就是说用户7天没有操作APP则需要重新登陆),如果某个接口被调用,则会重新刷新过期时间 public static function checktokens($token, $table) { $res = db::getOneForFields($table, 'time_out', 'token1 = ?', array($token)); if (!empty($res)) { if (time() - $res['time_out'] > 0) { return 90003; //token长时间未使用而过期,需重新登陆 } $new_time_out = time() + 604800;//604800是七天 if (db::setWhere($table, array('time_out' => $new_time_out), 'token1 = ?', array($token))) { return 90001; //token验证成功,time_out刷新成功,可以获取接口信息 } } return 90002; //token错误验证失败 }
관련 권장 사항:
PHP의 WeChat 공개 계정 확인 토큰, 회신 내용, 메시지 푸시 방법PHP 개발 APP 인터페이스 비디오 튜토리얼PHP 작성 앱 인터페이스 및 json 데이터 반환 예제 공유위 내용은 앱 인터페이스 토큰에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 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)

뜨거운 주제











Windows 운영 체제는 세계에서 가장 인기 있는 운영 체제 중 하나이며, 새로운 버전의 Win11이 많은 주목을 받았습니다. Win11 시스템에서 관리자 권한을 얻는 것은 사용자가 시스템에서 더 많은 작업과 설정을 수행할 수 있도록 하는 중요한 작업입니다. 이번 글에서는 Win11 시스템에서 관리자 권한을 얻는 방법과 권한을 효과적으로 관리하는 방법을 자세히 소개하겠습니다. Win11 시스템에서 관리자 권한은 로컬 관리자와 도메인 관리자의 두 가지 유형으로 나뉩니다. 로컬 관리자는 로컬 컴퓨터에 대한 모든 관리 권한을 갖습니다.

OracleSQL의 나눗셈 연산에 대한 자세한 설명 OracleSQL에서 나눗셈 연산은 두 숫자를 나눈 결과를 계산하는 데 사용되는 일반적이고 중요한 수학 연산입니다. 나누기는 데이터베이스 쿼리에 자주 사용되므로 OracleSQL에서 나누기 작업과 사용법을 이해하는 것은 데이터베이스 개발자에게 필수적인 기술 중 하나입니다. 이 기사에서는 OracleSQL의 나누기 작업 관련 지식을 자세히 설명하고 독자가 참고할 수 있는 특정 코드 예제를 제공합니다. 1. OracleSQL의 Division 연산

컴퓨터를 조립할 때 설치 과정은 간단하지만 배선에 문제가 발생하는 경우가 종종 있습니다. 컴퓨터가 켜지면 F1 오류 "CPUFanError"가 발생하며 이로 인해 CPU 쿨러가 지능적으로 속도를 조정할 수 없게 됩니다. 컴퓨터 마더보드의 CPU_FAN, SYS_FAN, CHA_FAN, CPU_OPT 인터페이스에 대한 상식을 공유해 보겠습니다. 컴퓨터 마더보드의 CPU_FAN, SYS_FAN, CHA_FAN 및 CPU_OPT 인터페이스에 대한 대중적인 과학 1. CPU_FANCPU_FAN은 CPU 라디에이터 전용 인터페이스이며 12V에서 작동합니다.

현대적이고 효율적인 프로그래밍 언어인 Go 언어에는 개발자가 유지 관리 가능한 고품질 코드를 작성하는 데 도움이 될 수 있는 풍부한 프로그래밍 패러다임과 디자인 패턴이 있습니다. 이 기사에서는 Go 언어의 일반적인 프로그래밍 패러다임과 디자인 패턴을 소개하고 구체적인 코드 예제를 제공합니다. 1. 객체지향 프로그래밍 Go 언어에서는 구조와 메소드를 사용하여 객체지향 프로그래밍을 구현할 수 있습니다. 구조를 정의하고 구조에 대한 바인딩 방법을 통해 데이터 캡슐화 및 동작 바인딩의 객체 지향 기능을 구현할 수 있습니다. 패키지메니

PHP의 모듈로 연산자(%)는 두 숫자를 나눈 나머지를 구하는 데 사용됩니다. 이 글에서는 모듈로 연산자의 역할과 사용법을 자세히 논의하고 독자의 이해를 돕기 위해 구체적인 코드 예제를 제공합니다. 1. 모듈로 연산자의 역할 수학에서는 정수를 다른 정수로 나누면 몫과 나머지가 나옵니다. 예를 들어 10을 3으로 나누면 몫은 3이고 나머지는 1입니다. 이 나머지를 얻기 위해 모듈로 연산자가 사용됩니다. 2. 모듈러스 연산자의 사용법 PHP에서는 모듈러스를 나타내기 위해 % 기호를 사용합니다.

PHP 인터페이스 소개 및 정의 방법 PHP는 웹 개발에 널리 사용되는 오픈 소스 스크립팅 언어입니다. 유연하고 간단하며 강력합니다. PHP에서 인터페이스는 여러 클래스 간의 공통 메서드를 정의하여 다형성을 달성하고 코드를 보다 유연하고 재사용 가능하게 만드는 도구입니다. 이 기사에서는 PHP 인터페이스의 개념과 이를 정의하는 방법을 소개하고 사용법을 보여주는 특정 코드 예제를 제공합니다. 1. PHP 인터페이스 개념 인터페이스는 클래스 애플리케이션을 정의하는 객체 지향 프로그래밍에서 중요한 역할을 합니다.

오류의 원인은 Python입니다. Tornado에서 NotImplementedError()가 발생하는 이유는 추상 메서드나 인터페이스가 구현되지 않았기 때문일 수 있습니다. 이러한 메서드나 인터페이스는 상위 클래스에서 선언되지만 하위 클래스에서는 구현되지 않습니다. 서브클래스가 제대로 작동하려면 이러한 메서드나 인터페이스를 구현해야 합니다. 이 문제를 해결하는 방법은 부모 클래스에서 선언한 추상 메서드나 인터페이스를 자식 클래스에 구현하는 것입니다. 다른 클래스에서 상속하기 위해 클래스를 사용하는 경우 이 오류가 표시되면 상위 클래스에 선언된 모든 추상 메서드를 하위 클래스에 구현해야 합니다. 인터페이스를 사용하고 있는데 이 오류가 표시되면 인터페이스를 구현하는 클래스의 인터페이스에 선언된 모든 메서드를 구현해야 합니다. 어느 것이 확실하지 않은 경우

Java를 사용하면 인터페이스 및 추상 클래스 내에서 내부 클래스를 정의할 수 있으므로 코드 재사용 및 모듈화에 대한 유연성이 제공됩니다. 인터페이스의 내부 클래스는 특정 기능을 구현할 수 있고, 추상 클래스의 내부 클래스는 일반 기능을 정의할 수 있으며, 서브클래스는 구체적인 구현을 제공합니다.
