search

Home  >  Q&A  >  body text

mysql - [php] Regarding the problem of php development app interface, please ask an experienced expert to answer it

php development app interface, user login problem

The situation is like this. After successful login, the previous user login interface is not saved on the server session. It may be saved on the app side. Therefore, even if the user logs in successfully, when adjusting certain interfaces, user_id must still be passed as a parameter instead of being obtained from the server's session.

Today I want to modify the login and registration interface. My colleague said that the app interface does not have the concept of session, but I always feel that there should be other ways to store user sessions on the server.

So I want to ask all the masters:

1. php开发app接口有没有`session`的概念?
2. 如果没有,用户会话是怎么处理的?就是当前是否在登录状态

Thank you everyone!

某草草某草草2812 days ago701

reply all(10)I'll reply

  • 巴扎黑

    巴扎黑2017-05-16 13:01:53

    You can take a look at jwt
    Self-contained: The payload contains all the information needed by the user

    reply
    0
  • 巴扎黑

    巴扎黑2017-05-16 13:01:53

    I set the token and expiration time, and use the token to verify

    reply
    0
  • 漂亮男人

    漂亮男人2017-05-16 13:01:53

    First, you create a login interface. The app calls this interface. After you verify the username and password passed by it, return a token to it.

    Token you create a table to save, and the table stores user_id token expire_data and other fields. Note that token and user_id are unique.

    Every time he requests other interfaces in the future, he only needs to bring this token to you, and you can verify the token.

    The passed token is encrypted/expired/guaranteed to be unique, which is basically it.

    reply
    0
  • 仅有的幸福

    仅有的幸福2017-05-16 13:01:53

    1. The request header contains the user usernamepassword ,到服务器端做验证,通过才继续下边业务逻辑。
    优点:防止了服务器端 api and is called at will.
    Disadvantages: The username and password are exchanged every time, the amount of interaction is large, and the clear text transmission of the password is unsafe.

    2. The first request requires username and password. After verification, cookie is sent to the client, usernamepassword ,验证通过,发送 cookie 到客户端, app 保存 cookie 值。
    每次请求带上 cookie
    优点:和 pc Save cookie< /code> value.

    Bring cookie with every request.

    Advantages: The principle of browser authentication on pc is the same.
    appOn the above two points, only registered users can have access to business logic.

    And some

    have a large number of APIs that do not require registration datatoken
    3. Develop a

    generation rule to generate a random string based on some common attributes shared by both the server and the client. The client generates this string, and the server verifies this string upon receiving the request.
    Disadvantage: The random string generation rules must be kept confidential.

    采纳答案

    If my answer solves your problem, please click
    🎜🎜

    reply
    0
  • ringa_lee

    ringa_lee2017-05-16 13:01:53

    It can be done like this. Different users obtain different tokens through the authorization interface, set the expiration time for the token, let the client put the token in the header for each request, and update the token regularly

    reply
    0
  • 滿天的星座

    滿天的星座2017-05-16 13:01:53

    Use token to replace the traditional session_id stored in the client cookie, and then the token is used as the key name in databases such as redis, and the key value is the user uid, and the session_id can be simulated through the built-in expiration mechanism

    reply
    0
  • 大家讲道理

    大家讲道理2017-05-16 13:01:53

    Our company has token and expiration time. Every time you log in, the token will be refreshed

    reply
    0
  • PHPz

    PHPz2017-05-16 13:01:53

    This is what I asked on our site when I was in doubt

    1. Your colleague said that the app does not have the concept of session, I don’t think it is accurate! I hope my previous questions are helpful to you!

    reply
    0
  • PHP中文网

    PHP中文网2017-05-16 13:01:53

    Login is when the server generates a successful login ID and returns it to the client. The client request brings the login ID, and the server verifies the user information by logging in

    reply
    0
  • 習慣沉默

    習慣沉默2017-05-16 13:01:53

    The safe thing to do is access_token. For this point, you can take a look at WeChat’s API interface;

    The simple way isuser_id;

    reply
    0
  • Cancelreply