高仿CMCC登录客户端

2023-10-24 12:10
文章标签 登录 客户端 高仿 cmcc

本文主要是介绍高仿CMCC登录客户端,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

import java.io.*;
import java.net.*;
import java.util.Scanner;import javax.swing.*;
public class Cmcc {// 设定参数private static String testPage;// 测试页面private String phoneNumber;// 手机号码private String password;// 登陆密码private static int checkTime;// 刷新时间private String sURL;// 递交的基本参数(包含session)private String rid;private String vlanid;private String rid1;private String session;private int errorNum = 0;// 连续读取测试页面异常的次数private static final int ERROR_NUM = 10;// 连续读取测试页面异常超过此次数则退出系统private static int outNum = 0;// 连接正常时输出的数字private URL url;/*** 初始化参数,如手机号码、密码* */public boolean init() {try {BufferedReader br = new BufferedReader(new FileReader("login.ini"));try {String ph = br.readLine();phoneNumber = ph.substring(ph.indexOf("手机号码") + 5,ph.indexOf(";"));if (phoneNumber.length() < 11) {JOptionPane.showMessageDialog(new JDialog(),"手机格式异常,请设置好配置文件再运行程序!");System.exit(0);}ph = br.readLine();password = ph.substring(ph.indexOf("登录密码") + 5, ph.indexOf(";"));if (password.length() == 0) {JOptionPane.showMessageDialog(new JDialog(),"密码没设置,请设置好配置文件再运行程序!");System.exit(0);}ph = br.readLine();checkTime = new Integer(ph.substring(ph.indexOf("检测间隔") + 5,ph.indexOf(";")));ph = br.readLine();testPage = ph.substring(ph.indexOf("测试连接是否正常的网页") + 12,ph.indexOf(";"));br.close();return true;} catch (Exception e) {JOptionPane.showMessageDialog(new JDialog(), "配置信息异常!");System.exit(0);}} catch (FileNotFoundException e) {Scanner sc = new Scanner(System.in);System.out.println("找不到配置文件,现在开始创建!");System.out.println("请输入登录手机号码:");String num = sc.next();System.out.println("请输入登录密码:");String pass = sc.next();String iniStr = "手机号码="+ num+ ";\n登录密码="+ pass+ ";\n检测间隔=10;(秒)\n测试连接是否正常的网页=http://www.baidu.com;\n\n注意:检测间隔建议设置10秒,格式请勿乱修改,出错自负";try {Writer wt = new FileWriter("login.ini");BufferedWriter bw = new BufferedWriter(wt);bw.write(iniStr);bw.flush();bw.close();wt.close();return false;} catch (IOException e1) {}}return false;}/*** 获取session信息并赋值给相关参数sURL* */public void setParameter() {try {// testPage = "http://www.baidu.com";url = new URL(testPage);BufferedReader br = new BufferedReader(new InputStreamReader(url.openStream(), "GBK"));br.readLine();// 第一行HTML信息,没用br.readLine();// 第二行HTML信息,没用// 把所读网页内容的第三行(主要信息都在这)赋值给新建的字符串bodyString body = br.readLine();System.out.println("setParameter_body:" + body);// 截取body中有用的信息rid = body.substring(body.indexOf("ipm=") + 5,body.indexOf("ipm=") + 13);vlanid = body.substring(body.indexOf("vlanid=") + 8,body.indexOf("vlanid=") + 10);rid1 = body.substring(body.indexOf("ss1=") + 5,body.indexOf("ss1=") + 17);String ss1 = body.substring(body.indexOf("ss3=") + 5,body.indexOf("ss3=") + 13);String ss2 = body.substring(body.indexOf("ss4=") + 5,body.indexOf("ss4=") + 17);String ss3 = body.substring(body.indexOf("ss2=") + 5,body.indexOf("ss2=") + 9);session = ss1 + "-" + ss2 + "-" + ss3;// 所有信息赋值给sURLsURL = "&rid=" + rid + "&vlanid=" + vlanid + "&rid1=" + rid1+ "&session=" + session;System.out.println("sURL:" + sURL);} catch (Exception e) {}}/*** 判断测试页面是否连接成功!成功返回0,掉线返回1,异常返回2* */public int isConn() {try {URL url = new URL(testPage);URLConnection conn = url.openConnection();conn.getDoInput();url.openStream();BufferedReader br = new BufferedReader(new InputStreamReader(url.openStream()));String er = "";// 读取3行信息,都没用的br.readLine();br.readLine();br.readLine();// 第4行有用,赋值给erer = br.readLine();if (er.indexOf("空间") == -1) {return 1;}errorNum = 0;return 0;} catch (Exception e) {if (errorNum > ERROR_NUM) {System.out.println("连续" + errorNum+ "次以上读取不到网络信息,系统自动退出!请确定你是否连接了CMCC网络!");System.exit(0);}errorNum++;return 2;}}/*** 登陆中国移动网络* */public void connCmcc() {try {URL url = new URL("http://218.204.219.1:8080/Control?id=2000"+ sURL);HttpURLConnection uc = (HttpURLConnection) url.openConnection();uc.setDoOutput(true);// uc.setRequestMethod("post");uc.setRequestProperty("User-Agent","Mozilla/4.0 (compatible; MSIE 6.0; Windows 2000)");OutputStreamWriter out = new OutputStreamWriter(uc.getOutputStream(), "8859_1");// 发送用户名密码out.write("strAccount=" + "18274959100" + "&strPassword=" + "0jud9n"+ "&");out.flush();out.close();System.out.println("登陆信息发送完毕,等待回复...如果等待过久请关闭程序!");BufferedReader br = new BufferedReader(new InputStreamReader(uc.getInputStream(), "GBK"));String er = null;while ((er = br.readLine()) != null) {if (er.indexOf("帐号或密码错误") != -1) {JOptionPane.showMessageDialog(new JDialog(),"帐号或密码错误,请修改参数文件!");System.exit(0);}}br.close();} catch (Exception e) {}}/*** 连接流程控制,连接正常返回true,不正常返回false* */public boolean systemControllor(Cmcc c) {if (!c.init())c.init();System.out.println("初始化参数正常!");c.setParameter();System.out.println("获取session等连接参数正常!");c.connCmcc();System.out.println("成功获得系统回复,验证网络是否通过...");while (c.isConn() != 0) {System.out.println("网络测试异常,系统重新连接!");return false;}return true;}/*** 系统定时刷新流程控制* */public void flushConn(Cmcc c) {while (true) {switch (c.isConn()) {case 0:outNum++;if (outNum > 9)outNum = 0;System.out.print(outNum);break;case 1:System.out.print("\n垃圾中国移动,又自动掉线了!系统重新连接...\n");while (!c.systemControllor(c))c.systemControllor(c);// JOptionPane.showMessageDialog(new JDialog(), "掉线了~~");break;case 2:System.out.print("\n我靠!网络不稳定,读不到信息");break;}try {Thread.sleep(checkTime * 1000);} catch (Exception e) {}}}/*** 主程序(废话)* */public static void main(String[] args) {System.out.println("================================");System.out.println("===CMCC自动连接系统(非UI版)===");System.out.println("================================");System.out.println("");Cmcc c = new Cmcc();while (!c.systemControllor(c))c.systemControllor(c);System.out.println("\n测试网页" + testPage + "成功!可以正常上网了!\n");System.out.println("系统间隔" + checkTime + "秒自动检测连接是否正常!");System.out.println("连接正常则会输出0~9的数字,不正常会有相应提示!");c.flushConn(c);}
}


 

下载:http://download.csdn.net/detail/weiyirong/8458689

这篇关于高仿CMCC登录客户端的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/275078

相关文章

Spring Boot基于 JWT 优化 Spring Security 无状态登录实战指南

《SpringBoot基于JWT优化SpringSecurity无状态登录实战指南》本文介绍如何使用JWT优化SpringSecurity实现无状态登录,提高接口安全性,并通过实际操作步骤... 目录Spring Boot 实战:基于 JWT 优化 Spring Security 无状态登录一、先搞懂:为什

在DataGrip中操作MySQL完整流程步骤(从登录到数据查询)

《在DataGrip中操作MySQL完整流程步骤(从登录到数据查询)》DataGrip是JetBrains公司出品的一款现代化数据库管理工具,支持多种数据库系统,包括MySQL,:本文主要介绍在D... 目录前言一、登录 mysql 服务器1.1 打开 DataGrip 并添加数据源1.2 配置 MySQL

Springboot中JWT登录校验及其拦截器实现方法

《Springboot中JWT登录校验及其拦截器实现方法》:本文主要介绍Springboot中JWT登录校验及其拦截器实现方法的相关资料,包括引入Maven坐标、获取Token、JWT拦截器的实现... 目录前言一、JWT是什么?二、实现步骤1.引入Maven坐标2.获取Token3.JWT拦截器的实现4.

Java Lettuce 客户端入门到生产的实现步骤

《JavaLettuce客户端入门到生产的实现步骤》本文主要介绍了JavaLettuce客户端入门到生产的实现步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 目录1 安装依赖MavenGradle2 最小化连接示例3 核心特性速览4 生产环境配置建议5 常见问题

90%的人第一步就错了! 顺利登录wifi路由器后台的技巧

《90%的人第一步就错了!顺利登录wifi路由器后台的技巧》登录Wi-Fi路由器,其实就是进入它的后台管理页面,很多朋友不知道该怎么进入路由器后台设置,感兴趣的朋友可以花3分钟了解一下... 你是不是也遇到过这种情况:家里网速突然变慢、想改WiFi密码却不知道从哪进路由器、新装宽带后完全不知道怎么设置?别慌

JWT + 拦截器实现无状态登录系统

《JWT+拦截器实现无状态登录系统》JWT(JSONWebToken)提供了一种无状态的解决方案:用户登录后,服务器返回一个Token,后续请求携带该Token即可完成身份验证,无需服务器存储会话... 目录✅ 引言 一、JWT 是什么? 二、技术选型 三、项目结构 四、核心代码实现4.1 添加依赖(pom

Spring Security重写AuthenticationManager实现账号密码登录或者手机号码登录

《SpringSecurity重写AuthenticationManager实现账号密码登录或者手机号码登录》本文主要介绍了SpringSecurity重写AuthenticationManage... 目录一、创建自定义认证提供者CustomAuthenticationProvider二、创建认证业务Us

Springboot项目登录校验功能实现

《Springboot项目登录校验功能实现》本文介绍了Web登录校验的重要性,对比了Cookie、Session和JWT三种会话技术,分析其优缺点,并讲解了过滤器与拦截器的统一拦截方案,推荐使用JWT... 目录引言一、登录校验的基本概念二、HTTP协议的无状态性三、会话跟android踪技术1. Cook

使用Redis快速实现共享Session登录的详细步骤

《使用Redis快速实现共享Session登录的详细步骤》在Web开发中,Session通常用于存储用户的会话信息,允许用户在多个页面之间保持登录状态,Redis是一个开源的高性能键值数据库,广泛用于... 目录前言实现原理:步骤:使用Redis实现共享Session登录1. 引入Redis依赖2. 配置R

Redis客户端连接机制的实现方案

《Redis客户端连接机制的实现方案》本文主要介绍了Redis客户端连接机制的实现方案,包括事件驱动模型、非阻塞I/O处理、连接池应用及配置优化,具有一定的参考价值,感兴趣的可以了解一下... 目录1. Redis连接模型概述2. 连接建立过程详解2.1 连php接初始化流程2.2 关键配置参数3. 最大连