Home Backend Development PHP Tutorial Demystifying HTTP 401 Unauthorized: Access Restriction Issues in PHP Development

Demystifying HTTP 401 Unauthorized: Access Restriction Issues in PHP Development

Apr 09, 2024 pm 04:06 PM
http restriction of visit Sensitive data

HTTP 401 Unauthorized error indicates that the server cannot accept unauthenticated requests. To resolve this issue, you can follow these steps: Enable HTTP Basic Authentication to prompt the user for credentials. Verify the provided credentials and only allow access to authorized users.

揭秘 HTTP 401 未授权:PHP 开发中的访问限制问题

Revealing HTTP 401 Unauthorized: Access Restriction Issues in PHP Development

HTTP 401 Unauthorized error code indicates that the server is not authorized Deny request without verification. This means that the server requires valid credentials to access protected resources. In PHP, you can easily generate this error code by using the HTTP_UNAUTHORIZED constant:

header('HTTP/1.1 401 Unauthorized');
Copy after login

To prevent unauthorized access, you can implement the following steps in your PHP application:

1. Enable HTTP Basic Authentication

// 在 PHP 脚本的顶部添加以下行:
header('WWW-Authenticate: Basic realm="Restricted Area"');
Copy after login

This will prompt the user to enter their username and password through a pop-up dialog box.

2. Verify credentials

if (isset($_SERVER['PHP_AUTH_USER']) && isset($_SERVER['PHP_AUTH_PW'])) {
  // 从服务器变量中获取提供的凭据
  $username = $_SERVER['PHP_AUTH_USER'];
  $password = $_SERVER['PHP_AUTH_PW'];
  
  // 检查凭据的有效性,例如:
  if ($username === 'admin' && $password === 'password') {
    // 授权已验证的用户
  } else {
    // 拒绝访问
    header('HTTP/1.1 401 Unauthorized');
  }
} else {
  // 拒绝访问,因为未提供凭据
  header('HTTP/1.1 401 Unauthorized');
}
Copy after login

Practical case

The following is a simple PHP script that shows how to protect the page And only allow access to authorized users:

<?php
// 启用 HTTP 基本身份验证
header('WWW-Authenticate: Basic realm="Protected Area"');

// 验证凭据
if (isset($_SERVER['PHP_AUTH_USER']) && isset($_SERVER['PHP_AUTH_PW'])) {
  $username = $_SERVER['PHP_AUTH_USER'];
  $password = $_SERVER['PHP_AUTH_PW'];

  // 检查凭据的有效性(例如,从数据库中检索)
  if ($username === 'john' && $password === 'example') {
    // 授权用户,显示受保护的内容
    echo '<h1>欢迎,' . $username . '!</h1>';
  } else {
    // 凭据无效,拒绝访问
    header('HTTP/1.1 401 Unauthorized');
  }
} else {
  // 未提供凭据,拒绝访问
  header('HTTP/1.1 401 Unauthorized');
}
?>
Copy after login

By following these steps, you can easily implement access restrictions in your PHP application to ensure that only authorized users can access sensitive data or resources.

The above is the detailed content of Demystifying HTTP 401 Unauthorized: Access Restriction Issues in PHP Development. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Best Graphic Settings
2 weeks ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

How is Douyin's IP address displayed? Does the IP address show real-time location? How is Douyin's IP address displayed? Does the IP address show real-time location? May 02, 2024 pm 01:34 PM

Users can not only watch a variety of interesting short videos on Douyin, but also publish their own works and interact with netizens across the country and even the world. In the process, Douyin’s IP address display function has attracted widespread attention. 1. How is Douyin’s IP address displayed? Douyin’s IP address display function is mainly implemented through geographical location services. When a user posts or watches a video on Douyin, Douyin automatically obtains the user's geographical location information. This process is mainly divided into the following steps: first, the user enables the Douyin application and allows the application to access its geographical location information; secondly, Douyin uses location services to obtain the user's geographical location information; finally, Douyin transfers the user's geographical location information Geographic location information is associated with the video data they posted or watched and will

Kingston U disk mass production tool - an efficient and convenient mass data copy solution Kingston U disk mass production tool - an efficient and convenient mass data copy solution May 01, 2024 pm 06:40 PM

Introduction: For companies and individuals who need to copy data in large quantities, efficient and convenient U disk mass production tools are indispensable. The U disk mass production tool launched by Kingston has become the first choice for large-volume data copying due to its excellent performance and simple and easy-to-use operation. This article will introduce in detail the characteristics, usage and practical application cases of Kingston's USB flash disk mass production tool to help readers better understand and use this efficient and convenient mass data copying solution. Tool materials: System version: Windows1020H2 Brand model: Kingston DataTraveler100G3 U disk software version: Kingston U disk mass production tool v1.2.0 1. Features of Kingston U disk mass production tool 1. Supports multiple U disk models: Kingston U disk volume

What is the value and use of icp coins? What is the value and use of icp coins? May 09, 2024 am 10:47 AM

As the native token of the Internet Computer (IC) protocol, ICP Coin provides a unique set of values ​​and uses, including storing value, network governance, data storage and computing, and incentivizing node operations. ICP Coin is considered a promising cryptocurrency, with its credibility and value growing with the adoption of the IC protocol. In addition, ICP coins play an important role in the governance of the IC protocol. Coin holders can participate in voting and proposal submission, affecting the development of the protocol.

How to implement HTTP streaming using C++? How to implement HTTP streaming using C++? May 31, 2024 am 11:06 AM

How to implement HTTP streaming in C++? Create an SSL stream socket using Boost.Asio and the asiohttps client library. Connect to the server and send an HTTP request. Receive HTTP response headers and print them. Receives the HTTP response body and prints it.

The meaning of * in sql The meaning of * in sql Apr 28, 2024 am 11:09 AM

In SQL means all columns, it is used to simply select all columns in a table, the syntax is SELECT FROM table_name;. The advantages of using include simplicity, convenience and dynamic adaptation, but at the same time pay attention to performance, data security and readability. In addition, it can be used to join tables and subqueries.

The difference between oracle database and mysql The difference between oracle database and mysql May 10, 2024 am 01:54 AM

Oracle database and MySQL are both databases based on the relational model, but Oracle is superior in terms of compatibility, scalability, data types and security; while MySQL focuses on speed and flexibility and is more suitable for small to medium-sized data sets. . ① Oracle provides a wide range of data types, ② provides advanced security features, ③ is suitable for enterprise-level applications; ① MySQL supports NoSQL data types, ② has fewer security measures, and ③ is suitable for small to medium-sized applications.

What does view mean in sql What does view mean in sql Apr 29, 2024 pm 03:21 PM

A SQL view is a virtual table that derives data from the underlying table, does not store actual data, and is dynamically generated during queries. Benefits include: data abstraction, data security, performance optimization, and data integrity. Views created with the CREATE VIEW statement can be used as tables in other queries, but updating a view actually updates the underlying table.

How to implement PHP security best practices How to implement PHP security best practices May 05, 2024 am 10:51 AM

How to Implement PHP Security Best Practices PHP is one of the most popular backend web programming languages ​​used for creating dynamic and interactive websites. However, PHP code can be vulnerable to various security vulnerabilities. Implementing security best practices is critical to protecting your web applications from these threats. Input validation Input validation is a critical first step in validating user input and preventing malicious input such as SQL injection. PHP provides a variety of input validation functions, such as filter_var() and preg_match(). Example: $username=filter_var($_POST['username'],FILTER_SANIT

See all articles