【Android 应用开发】Android 网络编程 API笔记 - java.net 包 权限 地址 套接字 相关类 简介(一)

简介: 【Android 应用开发】Android 网络编程 API笔记 - java.net 包 权限 地址 套接字 相关类 简介(一)

Android 网络编程相关的包 : 9 包, 20 接口, 103 类, 6 枚举, 14异常;


-- Java包 : java.net 包 (6接口, 34类, 2枚举, 12异常);


-- Android包 : android.net 包 (1接口, 19类, 3枚举, 1异常), android.net.http 包 (6类), android.net.nsd 包 (3接口, 2类), android.net.rtp (4类), android.net.sip 包 (1接口, 9类, 1异常), android.net.wifi 包 (16类, 1枚举), android.net.wifi.p2p 包 (9接口, 7类), android.net.wifi.p2p.nsd 包 (6类);






一. 权限相关类



1. Authenticator



类的全名称 :


public abstract class Authenticator extends Object

-- 作用 : 获取网络链接验证对象;


-- 使用方法 : 当需要获取一个带 口令 保护的文件的时候, 需要使用 用户名 和 密码 才能获取该文件的输入流, 如果遇到这种情况, 提示用户输入用户名 密码获取文件;




使用流程

1> 获取用户名密码

关键方法 :



protected PasswordAuthentication getPasswordAuthentication()

-- 重写方法 : 重写该方法, 在该方法中调用 该类中的其它方法, 获取关于请求验证的信息;

-- 用户输入 : 然后写一个 用户名密码输入框, 弹出该输入框, 通过用户输入获取用户名密码;


-- 返回结果 : 根据用户输入的 口令 密码 以及上面获取的请求验证信息, 返回 PasswordAuthentication 对象;




2> 验证


验证流程 :

-- 注册验证类实例 : 调用 setDefault(Authenticator) 方法向系统注册实例;

-- 验证 : 调用 requestPasswordAuthentication()方法;



public static void setDefault(Authenticator a)

-- 作用 : 设置 代理 或者 HTTP服务器 请求校验时 密码使用的 authenticator;




public static PasswordAuthentication requestPasswordAuthentication(InetAddress addr,
            int port,
            String protocol,
            String prompt,
            String scheme)

-- 作用 : 要求向系统注册的 authemticator 提供密码;

-- 参数 : addr 请求授权站点的 InetAddress, port 请求链接端口, protocol 请求连接的协议, prompt 用户提示的字符串, scheme 验证方案;






2. PasswordAuthentication



类的全名称 :


public final class PasswordAuthentication extends Object

-- 作用 : 该类保存 Authenticator 使用的 用户名 和 密码;



构造方法 :



public PasswordAuthentication(String userName, char[] password)

-- 用法 : 根据传入的用户名 和 密码创建 PasswordAuthentication 对象;



获取用用户名密码的方法 :


-- 获取用户名方法 : public String getUserName() ;


-- 获取密码方法 : public char[] getPassword() ;






3. NetPermission



类的全名称 :



public final class NetPermission extends BasicPermission

-- 作用 : 用于各种网络权限, 包含一个名称, 没有动作列表;



权限解析 : 每个权限都有一个权限名称, 所允许的操作, 以及对应的风险;


-- setDefaultAuthenticator : 设置代理 或 HTTP 服务器请求验证, 获取验证信息的方式;


-- requestPasswordAuthentication : 设置 在系统中注册的 authenticator 可以提供密码;


-- specifyStreamHandler : 构造 URL 时指定流处理程序;


-- setProxySelector : 设置 建立网络连接时使用代理的 代理选择器;


-- getProxySelector : 获取 建立网络连接时使用代理的 代理选择器;


-- setCookieHandler : 设置 HTTP会话处理高度安全敏感的cookie 的 cookie 处理程序;


-- getCookieHandler : 获取 HTTP会话处理高度安全敏感的cookie 的 cookie 处理程序;


-- setResponseCache : 设置 本地响应缓存的访问权限;


-- getResponseCache : 获取 本地响应缓存的访问权限;


.






二. 地址相关类



1. InetAddress



类的全名称 :


public class InetAddress extends Object implements Serializable


作用 : 代表 IP 地址;


IP地址层级 : IP地址是一种低级的协议, UDP 和 TCP 都是在这个协议的基础上构建;




IP地址类型 :


-- 单播地址 : 用于当作单个接口标识符, 发送到单播地址的数据包 被发送到 由该地址标识的接口;


-- 多播地址 : 用于当作一组接口的标识符, 发送到多播地址的数据包被交付给由地址标识的所有接口;


-- 回送地址 : 分配给回送接口的地址, 发送到回送地址的任何内容, 都将当作本地主机的IP输入, 通常在测试客户机的时候使用这种类型的地址;




多播地址的注意事项 : 不能将多播地址分配给任何节点, 它是 anylocal 地址 或者 通配符地址, 服务器主机有多个接口的情况下接收任何接口上的客户端链接;




IP地址范围 :


-- 链接本地地址 : 在单个链接上寻址, 以解决诸如自动地址配置, 邻居发现, 或者没有路由器的问题;


-- 站点本地地址 : 不许要全局前缀时, 站点内部寻址;


-- 全局地址 : Internet中唯一的地址;




IP地址文本表现形式 : 有 IPv4 IPv6 两种格式;




主机名解析 :


-- 主机名到IP地址解析 : 使用 本地配置信息 和 网络命名服务 实现, 特定命名服务默认情况下 是本地机器配置的;


-- 反向名称解析 : 返回IP地址对应的主机名;




InetAddress 缓存 : 存储 主机名解析, 不管成功还是失败;


-- 默认缓存 : 正确解析的主机名 解析结果会永久保存, 如果解析失败 该记录只保存10秒;


-- 正主机名解析缓存 : 使用 networkaddress.cache.ttl 成功解析的缓存策略, 用于设置java安全属性设置为另外的 TTL 值进行正缓存;


-- 负主机名解析缓存 : 使用 networkaddress.cache.negative.ttl 解析主机名失败的缓存策略;






2. Inet4Address



类的全名称 :



public final class Inet4Address extends InetAddress

-- 作用 : 表示 IPv4 地址;



IP地址文本表示形式 :


-- 指定4部分 : d.d.d.d , 每个部分都是一个字节数据, 从左到右 分配给 IPv4 四个字节;


-- 指定3部分 : d.d.d , 最后一部分是2个字节, 放在最右边的网络地址上;


-- 指定2部分 : d.d , 最后一部份是3个字节, 放在最右边的三个字节上;


-- 指定1部分 : d , 直接存储在网络地址中, 字节不用重新排列;




多播地址范围 : IPv4 生存时间 (Time-to-live) 作为多播范围字段库增加一倍;


-- TTL = 0 : 表示节点本地;


-- TTL = 1 : 表示链接本地;


-- TTL = 32 : 表示站点本地;


-- TTL = 64 : 表示地区本地;


-- TTL = 128 : 表示大陆本地;


-- TTL = 255 : 表示全球;




3. Inet6Address



类的全名称 :



public final class Inet6Address extends InetAddress

-- 作用 : 代表 IPv6 地址;


目录
相关文章
|
8天前
|
消息中间件 Java Linux
2024年最全BATJ真题突击:Java基础+JVM+分布式高并发+网络编程+Linux(1),2024年最新意外的惊喜
2024年最全BATJ真题突击:Java基础+JVM+分布式高并发+网络编程+Linux(1),2024年最新意外的惊喜
|
6天前
|
安全 Java 开发者
使用Spring Boot简化Java应用开发
【5月更文挑战第22天】Spring Boot简化Java应用开发,基于Spring框架,提供自动化配置、内置功能组件和微服务支持。通过Spring Initializr快速创建项目,选择依赖并生成代码。开发时,利用其内嵌Web服务器、日志及监控功能。打包后,可独立运行或部署,无需额外容器。掌握Spring Boot对Java开发者至关重要。
|
13天前
|
存储 安全 物联网
使用 Java 进行物联网(IoT)应用开发
【4月更文挑战第19天】Java,凭借其跨平台特性和丰富库,成为物联网开发热门选择。开发者利用Java进行物联网应用开发,可实现设备连接、数据处理、数据库管理及安全保障。熟悉Java基础、物联网知识、数据通信和数据库管理是必备技能。利用MQTT客户端、数据存储框架和可视化工具能提升开发效率。随着物联网发展,Java在该领域的影响力将持续增强。
|
13天前
|
网络协议 算法 Java
【Java网络编程】网络编程概述、UDP通信(DatagramPacket 与 DatagramSocket)
【Java网络编程】网络编程概述、UDP通信(DatagramPacket 与 DatagramSocket)
28 3
|
13天前
|
人工智能 Java API
Spring AI 抢先体验,5 分钟玩转 Java AI 应用开发
Spring Cloud Alibaba AI 以 Spring AI 为基础,并在此基础上提供阿里云通义系列大模型全面适配,让用户在 5 分钟内开发基于通义大模型的 Java AI 应用。
225191 10
|
13天前
|
安全 网络安全 数据安全/隐私保护
【专栏】IT 知识百科:访问控制列表(ACL)是网络安全的关键机制,用于定义和管理网络资源的访问权限
【4月更文挑战第28天】访问控制列表(ACL)是网络安全的关键机制,用于定义和管理网络资源的访问权限。ACL工作原理包括定义规则、匹配规则和执行操作。标准ACL基于源IP过滤,扩展ACL则提供更多筛选条件。时间及用户基础的ACL提供更细化的控制。优点在于增强安全性和精细管理,但管理复杂性和性能影响也是挑战。未来,ACL将趋向智能化和自动化,与更多安全技术结合,以提升网络安全。**
|
3天前
|
网络协议 Java API
Java 网络编程
5月更文挑战第19天
|
13天前
|
Java 开发者 Spring
Java一分钟之-Java网络编程基础:Socket通信
【5月更文挑战第13天】本文介绍了Java Socket编程基础知识,包括使用`ServerSocket`和`Socket`类建立连接,通过`OutputStream`和`InputStream`进行数据传输。常见问题涉及忘记关闭Socket导致的资源泄漏、网络异常处理及并发同步。理解Socket通信原理并掌握异常处理、资源管理和并发控制,能帮助开发者构建更稳定的网络应用。
39 1
|
13天前
|
网络协议 Dubbo Java
【网络编程】理解客户端和服务器并使用Java提供的api实现回显服务器
【网络编程】理解客户端和服务器并使用Java提供的api实现回显服务器
15 0
|
13天前
|
SQL 存储 Java
令应用开发效率飙升的 Java 类库
更多地使用 Java 而避免存储过程和复杂 SQL 是当前应用开发的一个潮流,这会在架构上带来优势,但用 Java 实现 SQL 式的运算并不是非常方便,很多任务要从头写起,开发效率其实反而会降低。