java 判断一个url是否可以访问的方法

有些时候,我们需要判断某个url是否可以访问,可以访问了,才允许继续进行,目前有两种方式,最后使用带超时时间的,
因为第一种超时时间不定,可能会出现阻塞的情况。

package com.url;

import java.io.InputStream;
import java.net.URL;
import java.net.URLConnection;

public class TestUrl {

    public static void main(String[] args) {

        testUrl("http://1.3.3.3/test");
        //最好使用下面这个,上面那个超时时间不定,所以可能会导致卡住的情况
        testUrlWithTimeOut("http://1.3.3.3", 2000);
    }
    
    public static void testUrl(String urlString){
        
        long lo = System.currentTimeMillis();
        URL url;  
        try {  
             url = new URL(urlString);  
             InputStream in = url.openStream();  
             System.out.println("连接可用");  
        } catch (Exception e1) {  
             System.out.println("连接打不开!");  
             url = null;  
        }  
        
        System.out.println(System.currentTimeMillis()-lo);
    }
    
    public static void testUrlWithTimeOut(String urlString,int timeOutMillSeconds){
        long lo = System.currentTimeMillis();
        URL url;  
        try {  
             url = new URL(urlString);  
             URLConnection co =  url.openConnection();
             co.setConnectTimeout(timeOutMillSeconds);
             co.connect();
             System.out.println("连接可用");  
        } catch (Exception e1) {  
             System.out.println("连接打不开!");  
             url = null;  
        }  
        System.out.println(System.currentTimeMillis()-lo);
    }
}



  • 7
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Java中,可以通过判断session变量是否存在来判断用户是否登录。如果指定名称的session变量不存在,即为null,那么可以判定用户尚未登录。推荐的验证方式是使用以下代码: ```java Object pwd = session.getAttribute("loginUserPwd"); if (pwd == null) { out.print("你还没有登录"); //...其他代码... } else { out.print("你已经登录了"); //...其他代码... } ``` 这种方式可以简单地判断用户是否登录。然而,在多用户的情况下,如果一个用户登录后,使用适当的URL即可访问一个用户的资料,这是不希望出现的。因此,在这种情况下,验证不能仅仅判断session变量是否为空,而是需要通过session变量是否等于用户自己设置的某个密码来判断是否是自己本人登录。这样可以将登录验证细化到用户级别,确保每个用户只能管理自己的资料。 ```java Object pwd = session.getAttribute("loginUserPwd"); String clientPWD = (String) session.getAttribute("loginUserPwd"); //数据来源客户端用户的输入 String serverPWD = "XXX"; //这个密码来源于服务器端某个文件或DB中,是用户自己事先设置好的 if (pwd == null || !clientPWD.equals(serverPWD)) { out.print("你还没有登录,或不是自己本人登录"); //...其他代码... } else { out.print("你已经登录了,并且是自己登录"); //...其他代码... } ``` 通过这种方式,可以确保用户登录验证更加安全和准确。 #### 引用[.reference_title] - *1* *2* *3* [Java登录验证问题](https://blog.csdn.net/weixin_44355164/article/details/89407987)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值