# Creating a secure login process between your app and server

This page explains how to securely handle user registration and login when implementing LINE Login in your native app using the LINE SDK.

# Information that's safe to send and receive

When a user logs in to your app via LINE Login, the client app and server can send and receive this information from the LINE Platform:

  • ❌ User profile details
  • ❌ Channel IDs

However, information such as the above is vulnerable to spoofing and other kinds of attacks. For example, it's dangerous for your server to blindly trust this information when your client sends it. Instead, your client should send this data to your server:

  • ✅ Access tokens
  • ✅ ID tokens

These tokens enable your server to get reliable information directly from the LINE Platform.

How to use this page

This section explains the design concepts we recommend for using the LINE SDK. They are guides, not templates. Be sure to build a safe system with a full understanding of the dangers.

# Using access tokens to register new users

When a new user logs in to your app using LINE Login, you'll want to use their LINE profile details to create a new user in your database.

However, if you allow the client app to send you profile information directly to your server, you make yourself vulnerable to attacks.

Note

The following example highlights a potential vulnerability in the user registration and login process.

Instead of profile information, the client app sends an access token to the server. The server should verify the access token and retrieve the user profile directly from the LINE Platform:

To learn more about the API calls in the diagram, see these topics in the LINE Login v2.1 API reference:

Further confirmation is required after verifying the access token

When the LINE Login API successfully verifies an access token, the response contains a client_id property (the channel ID) and an expires_in property (the amount of time until the token expires). Make sure that these properties satisfy the following criteria before you use the access token.

Property Criteria
client_id Same as the channel ID of the LINE Login channel linked to the native app
expires_in Positive value

# Using OpenID to register new users

If your app supports OpenID Connect (opens new window), it's not necessary to verify the access token. Instead, the client app sends the ID token to the server. The server should use an endpoint provided by the LINE Platform to validate your ID token to get a user profile information:

nonce: number used once

The nonce is a randomly generated number used to make each login attempt uniquely identifiable.

Using nonce correctly helps prevent replay attacks (opens new window).

For more information on the API call in the diagram, see this topic in the LINE Login API reference:

For details about how to handle the ID token and nonce on your server, see these items:

# Next steps

The preceding examples show in general terms how to design a secure user registration and login process. But for specific instructions on integrating LINE Login into your app, see these items: