Web Service 使用时出现 HTTP Status 401: Unauthorized




在调用 Web Service 时,实际遇到的情况:

1, 如果当前用户有权限,且IIS 中设定禁止匿名访问,则需要在代码中增加以下代码:

webService.UseDefaultCredentials = true

2,如果当前用户没有权限,但IIS 中设定禁止匿名访问,就会出现此401 错误,可开启匿名访问解决:

enable anonymous authentication

3,如果当前用户没有权限,但IIS 中设定禁止匿名访问,会出现401 错误,在不开启匿名访问的前提下,需要在代码中加入对应的认证代码解决:

ws.Credentials = new System.Net.NetworkCredential(_userID, _password);




参看以下文章:

Http 401错误重现实验及解决办法

http://blog.csdn.net/directionofear/article/details/8042755



  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我可以为您提供一些指导。 首先,您需要创建一个Spring Boot项目并添加所需的依赖项。您需要添加Spring Boot Starter Web和Spring Boot Starter Data JPA依赖项。在pom.xml文件中添加以下依赖项: ``` <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-jpa</artifactId> </dependency> <dependency> <groupId>com.h2database</groupId> <artifactId>h2</artifactId> <scope>runtime</scope> </dependency> </dependencies> ``` 这些依赖项将为您提供Spring Boot Web和Spring Boot Data JPA的支持。还添加了H2数据库支持,以便您可以在本地运行应用程序。 接下来,您需要创建一个用户实体。用户实体将用于存储用户的详细信息,例如用户名,密码等。以下是一个简单的用户实体类: ``` @Entity @Table(name = "users") public class User { @Id @GeneratedValue(strategy = GenerationType.AUTO) private Long id; @Column(nullable = false, unique = true) private String username; @Column(nullable = false) private String password; // Getters and setters } ``` 在这个实体中,我们使用了@Entity和@Table注释来指定实体名称和表名称。我们还为每个属性指定了@Column注释,以便JPA可以将它们映射到表的列。 接下来,您需要创建一个用户存储库。用户存储库将用于处理与用户相关的操作,例如创建用户,查找用户等。以下是一个简单的用户存储库: ``` @Repository public interface UserRepository extends JpaRepository<User, Long> { Optional<User> findByUsername(String username); } ``` 在这个存储库中,我们使用了@Repository注释来指定它是一个Spring Bean。我们还扩展了JpaRepository来获得标准的CRUD操作。我们还添加了一个findByUsername方法,以便我们可以根据用户名查找用户。 接下来,您需要创建一个用户服务。用户服务将处理与用户相关的业务逻辑,例如验证用户,创建用户等。以下是一个简单的用户服务: ``` @Service public class UserService { private final UserRepository userRepository; public UserService(UserRepository userRepository) { this.userRepository = userRepository; } public User createUser(String username, String password) throws UserAlreadyExistsException { Optional<User> existingUser = userRepository.findByUsername(username); if (existingUser.isPresent()) { throw new UserAlreadyExistsException(); } User user = new User(); user.setUsername(username); user.setPassword(passwordEncoder().encode(password)); return userRepository.save(user); } public User authenticateUser(String username, String password) throws UserNotFoundException, InvalidPasswordException { Optional<User> optionalUser = userRepository.findByUsername(username); User user = optionalUser.orElseThrow(UserNotFoundException::new); if (!passwordEncoder().matches(password, user.getPassword())) { throw new InvalidPasswordException(); } return user; } private PasswordEncoder passwordEncoder() { return new BCryptPasswordEncoder(); } } ``` 在这个服务中,我们使用了@Service注释来指定它是一个Spring Bean。我们还注入了一个UserRepository,以便我们可以使用它来处理与用户相关的操作。 我们添加了两个方法:createUser和authenticateUser。createUser方法将创建一个新用户,并将其保存到数据库中。authenticateUser方法将验证用户的凭据,并返回用户对象。 在上面的代码中,您可能已经注意到我们使用了一个PasswordEncoder来处理密码。这是一个用于密码加密和解密的Spring Security组件。在这个示例中,我们使用了BCryptPasswordEncoder。 最后,您需要创建一个控制器来处理HTTP请求。以下是一个简单的控制器: ``` @RestController @RequestMapping("/users") public class UserController { private final UserService userService; public UserController(UserService userService) { this.userService = userService; } @PostMapping("/register") public User registerUser(@RequestBody UserDTO userDTO) throws UserAlreadyExistsException { return userService.createUser(userDTO.getUsername(), userDTO.getPassword()); } @PostMapping("/login") public User loginUser(@RequestBody UserDTO userDTO) throws UserNotFoundException, InvalidPasswordException { return userService.authenticateUser(userDTO.getUsername(), userDTO.getPassword()); } @ExceptionHandler({UserAlreadyExistsException.class, UserNotFoundException.class, InvalidPasswordException.class}) public ResponseEntity<String> handleException(Exception e) { return ResponseEntity.status(HttpStatus.UNAUTHORIZED).body(e.getMessage()); } } ``` 在这个控制器中,我们使用了@RestController和@RequestMapping注释来指定它是一个Spring MVC控制器。我们还注入了UserService,以便我们可以使用它来处理与用户相关的业务逻辑。 我们添加了两个端点:registerUser和loginUser。registerUser将创建一个新用户,并返回用户对象。loginUser将验证用户的凭据,并返回用户对象。 我们还添加了一个ExceptionHandler方法,以便我们可以捕获和处理异常。在这个示例中,我们返回了一个HTTP 401 Unauthorized响应。 这就是您需要实现的所有内容。您可以使用POSTMAN或其他HTTP客户端来测试这些端点。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值