Android 热点二维码简单示例
Android 热点二维码简单示例
一、前言
Android 原生设置有热点二维码分享功能,有些系统应用也会有这个需求。
下面看看是如何实现的。
本文是一个比较简单的内容。
二、热点二维码生成实现
1、效果

整个应用就一个普通的Activity,+显示一个按钮和二维码图片;
上面的输入框默认是热点密码的格式,修改输入后可以重新生成;
还添加了点击二维码图片,放大效果,如下图所示:

一般新的手机使用相机扫描可以识别连接热点,或者wifi设置里面也可以扫描连接热点;
上面这个二维码也可以直接打印使用,
如果你的wifi名称修改成test,密码修改成12345678,别人在附近扫描这个二维码就能连接。
2、主要知识点
(1)热点密码字符串格式
固定格式格式:WIFI:T:WifiType;S:WifiName;P:WifiPassword;;示例:
//加密类型:WPA2,wifi名称:test,wifi密码:12345678
WIFI:T:WPA2;S:test;P:12345678;;//没有密码的wifi:
WIFI:T:nopass;S:test;P:;;
(2)字符串生成二维码图片:
implementation 'com.google.zxing:core:3.4.1'
app build.gradle 导入zxing包就可以调用相关方法生成Bitmap对象放到ImageView显示。//字符串上层二维码Bitmap对象封装方法:public static Bitmap createQrcode(String text) {Log.v(TAG, "createQrcode text = " + text);if (TextUtils.isEmpty(text)) {return null;}try {String contents = new String(text.getBytes("UTF-8"), "ISO-8859-1");MultiFormatWriter formatWriter = new MultiFormatWriter();BitMatrix bitMatrix = formatWriter.encode(contents, BarcodeFormat.QR_CODE, 800, 800);return bitMatrix2Bitmap(bitMatrix);} catch (Exception e) {e.printStackTrace();}return null;}
3、demo代码
两个类:一个Activity类和一个工具类。
(1)MainActivity.java
package com.example.qrcode;import android.app.Dialog;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.ImageView;
import android.widget.Toast;import androidx.activity.EdgeToEdge;
import androidx.appcompat.app.AlertDialog;
import androidx.appcompat.app.AppCompatActivity;public class MainActivity extends AppCompatActivity implements View.OnClickListener {EditText et_input;Button btn_create_qrcode;ImageView imageView;String TAG = "MainActivity";@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);EdgeToEdge.enable(this);setContentView(R.layout.activity_main);initView();initData();initEvent();}private void initView() {btn_create_qrcode = findViewById(R.id.btn_create_qrcode);et_input = findViewById(R.id.et_input);imageView = findViewById(R.id.iv_qrcode);}private void initData() {//TestString testText = "WIFI:T:WPA2;S:test;P:12345678;;";//wifi名称:test,密码:12345678//String testText = QrcodeUtils.createQrcode(QrcodeUtils.getHotspotQrcodeString(this)); //热点二维码字符串imageView.setImageBitmap(QrcodeUtils.createQrcode(testText));et_input.setText(testText);}private void initEvent() {btn_create_qrcode.setOnClickListener(this);imageView.setOnClickListener(this);}//点击事件@Overridepublic void onClick(View v) {switch (v.getId()) {case R.id.btn_create_qrcode:Toast.makeText(this, "创建了二维码", Toast.LENGTH_SHORT).show();String text = et_input.getText().toString();Log.i(TAG, "text: " + text);imageView.setImageBitmap(QrcodeUtils.createQrcode(text));break;case R.id.iv_qrcode:Toast.makeText(this, "点击了二维码", Toast.LENGTH_SHORT).show();View view = getLayoutInflater().inflate(R.layout.dialog_qrcode, null);ImageView imageView = view.findViewById(R.id.iv_qrcode_dialog);imageView.setImageBitmap(QrcodeUtils.createQrcode("WIFI:T:WPA2;S:test;P:12345678;;"));Dialog alertDialog = new AlertDialog.Builder(this).setView(view).create();alertDialog.show();break;}}
}
上面就是一个普通的Activity代码,比较简单易懂。
(2)QrcodeUtils.java
package com.example.qrcode;import com.google.zxing.BarcodeFormat;
import com.google.zxing.MultiFormatWriter;
import com.google.zxing.common.BitMatrix;import android.content.Context;
import android.graphics.Bitmap;
import android.graphics.Bitmap.Config;
import android.graphics.Color;
import android.util.Log;
import android.net.wifi.SoftApConfiguration;
import android.net.wifi.WifiManager;
import android.text.TextUtils;public class QrcodeUtils {private static final String TAG = QrcodeUtils.class.getSimpleName();//字符串生成Bitmap对象public static Bitmap createQrcode(String text) {Log.v(TAG, "createQrcode text = " + text);if (TextUtils.isEmpty(text)) {return null;}try {String contents = new String(text.getBytes("UTF-8"), "ISO-8859-1");MultiFormatWriter formatWriter = new MultiFormatWriter();BitMatrix bitMatrix = formatWriter.encode(contents, BarcodeFormat.QR_CODE, 800, 800);return bitMatrix2Bitmap(bitMatrix);} catch (Exception e) {e.printStackTrace();}return null;}private static Bitmap bitMatrix2Bitmap(BitMatrix matrix) {int w = matrix.getWidth();int h = matrix.getHeight();int[] rawData = new int[w * h];for (int i = 0; i < w; i++) {for (int j = 0; j < h; j++) {int color = Color.WHITE;if (matrix.get(i, j)) {color = Color.BLACK;}rawData[i + (j * w)] = color;}}Bitmap bitmap = Bitmap.createBitmap(w, h, Config.RGB_565);bitmap.setPixels(rawData, 0, w, 0, 0, w, h);return bitmap;}//获取热点二维码规则的字符串public static String getHotspotQrcodeString(Context context) {WifiManager wifiManager = (WifiManager) context.getSystemService(Context.WIFI_SERVICE);if (wifiManager == null) {return null;}SoftApConfiguration config = wifiManager.getSoftApConfiguration(); //getSoftApConfiguration()方法需要导入framework jar包才能章程编过String wifiName = "";String wifiPassWord = "";wifiName = config.getSsid();wifiPassWord = config.getPassphrase();int securityType = config.getSecurityType();String security = "WPA2";//判断是否设置了热点密码,如果未设置热点密码不用设置密码字符串if (securityType == SoftApConfiguration.SECURITY_TYPE_OPEN) {wifiPassWord = "";security = "nopass";}StringBuilder build = new StringBuilder();build.append("WIFI:T:").append(security).append(";S:").append(wifiName).append(";P:").append(wifiPassWord).append(";;");return build.toString();}}
上面就是一个工具类,主要包含两个工具方法:
一个是字符串创建二维码Bitmap对象;
一个是获取热点二维码的字符串;
(3)热点二维码
上面的demo代码,默认是普通字符串的二维码生成;
如果要换成本机设备的热点二维码的生成,把字符串生成的方法替换成 getHotspotQrcodeString()方法就行;
但是要注意的是热点信息的获取是要系统签名权限的;
所以要热点字符串生成导入系统签名的jks;
并且需要在AndroidManifest中声明uid:
<manifest xmlns:android="http://schemas.android.com/apk/res/android"xmlns:tools="http://schemas.android.com/tools"android:sharedUserId="android.uid.system">
还有就是要添加权限:
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
还有就是要导入系统的framework 的jar包:
未导入系统jar包下面的代码会编译错误:
WifiManager.getSoftApConfiguration();
4、扩展一下
其实不仅仅是手机热点的wifi可以用二维码,普通的wifi也是可以使用二维码;
只要把上面的账号和密码替换就行;后面就可以提供二维码给别人进行扫描连接wifi;
所以在现实场景中也可以提前生成对应的wifi名称和密码的二维码,保留使用;
特别是很长的wifi名称或者密码的情况,使用二维码扫描连接更加方便。
5、资源下载
项目代码和apk应用代码下载路径:
https://download.csdn.net/download/wenzhi20102321/90640480
apk可以直接下载安装使用;可以定制自己需要的wifi账号和密码的二维码图片。
三、其他
1、Android 热点二维码简单示例小结
(1)热点二维码固定格式格式:WIFI:T:WifiType;S:WifiName;P:WifiPassword;;
(2)生成二维码图片使用zxing包的相关类
(3)如果应用需要生成设备当时的热点二维码图片,需要系统签名权限命令
手机联系人的二维码呢?也是这样的二维码吗?
其实这些码都不一样,像微信个人二维码,挪车码,支付宝的码,
这些二维码都是包含网址和相关信息的,需要通过具体服务器校验才能跳转到另外界面。
2、之前的二维码和热点介绍
Android二维码图片生成和二维码扫描软件的设计
https://blog.csdn.net/wenzhi20102321/article/details/53316179
Android 热点分享二维码功能简单介绍
https://blog.csdn.net/wenzhi20102321/article/details/142603112
之前没介绍这么具体,并且没有提供到apk和源码。
相关文章:
Android 热点二维码简单示例
Android 热点二维码简单示例 一、前言 Android 原生设置有热点二维码分享功能,有些系统应用也会有这个需求。 下面看看是如何实现的。 本文是一个比较简单的内容。 二、热点二维码生成实现 1、效果 整个应用就一个普通的Activity,显示一个按钮和二维…...
探秘Python 工匠:案例、技巧与工程实践:解锁Python进阶的通关秘籍
重要的放前面 Python 工匠:案例、技巧与工程实践 探秘Python 工匠:案例、技巧与工程实践:解锁Python进阶的通关秘籍 在Python的编程世界中,从入门小白到技术大牛的进阶之路往往充满挑战。Python工匠:案例、技巧与工…...
JAVAEE(网络原理—UDP报头结构)
我们本篇文章要讲的是UDP的报头结构以及注意事项。 下面呢,我先说一下UDP是什么? 1.UDP是什么? UDP是一种网络协议。网络协议是计算机网络中,为了使不同设备之间能够准确、高效地进行数据交换和通信,而预先制定的一…...
通过docker create与export来分析诊断故障镜像
🧑 博主简介:CSDN博客专家,历代文学网(PC端可以访问:https://literature.sinhy.com/#/?__c1000,移动端可微信小程序搜索“历代文学”)总架构师,15年工作经验,精通Java编…...
LINUX419 更换仓库(没换成)find命令
NAT模式下虚拟机需与网卡处在同一个网段中吗 和VM1同个网段 会不会影响 这个很重要 是2 改成点2 倒是Ping通了 为啥ping百度 ping到别的地方 4399 倒是ping通了 准备下载httpd包 下不下来 正在替换为新版本仓库 报错 failure: repodata/repomd.xml from local: [Er…...
鸿蒙学习笔记(5)-HTTP请求数据
一、Http请求数据 http模块是鸿蒙内置的一个模块,提供了网络请求的能力。不需要再写比较原始的AJAS代码。 ps:在项目中如果要访问网络资源,不管是图片文件还是网络请求,必须给项目开放权限。 (1)网络连接方式 HTTP数…...
AI文生图工具推荐
一、AI文生图技术实现原理 AI文生图(Text-to-Image)基于生成对抗网络(GAN)或扩散模型(Diffusion Model)实现,通过深度学习将文本描述转化为图像。其核心流程包括: 文本编码…...
Spark-SQL核心编程
Spark-SQL核心编程 数据加载与保存 加载数据 spark.read.load 是加载数据的通用方法。如果读取不同格式的数据,可以对不同的数据格式进行设定 保存数据 df.write.save 是保存数据的通用方法。如果保存不同格式的数据,可以对不同的数据格式进行设定 …...
github 项目迁移到 gitee
1. 查看远程仓库地址 git remote -v 2. 修改远程仓库地址 确保 origin 指向你的 Gitee 仓库,如果不是,修改远程地址。 git remote set-url origin https://gitee.com/***/project.git 3. 查看本地分支 git branch 4. 推送所有本地分支 git p…...
AcWing 11:背包问题求方案数 ← 0-1背包
【题目来源】 https://www.acwing.com/problem/content/11/ 【题目描述】 有 N 件物品和一个容量是 V 的背包。每件物品只能使用一次。 第 i 件物品的体积是 vi,价值是 wi。 求解将哪些物品装入背包,可使这些物品的总体积不超过背包容量,且总…...
React应用开发学习指南
AI生成研究报告:关键词 React应用开发 React 已经成为前端 Web 开发领域的主导力量,它是一个免费且开源的 JavaScript 库,主要用于构建用户界面 (UI) 1。其多功能性延伸到为 Web 和原生应用程序创建 UI,使其成为行业内备受追捧的…...
LVGL源码(9):学会控件的使用(自定义弹窗)
LVGL版本:8.3 LVGL的控件各式各样,每种控件都有自己的一些特性,当我们想要使用一个LVGL控件时,我们首先可以通过官网去了解控件的一些基本特性,官网链接如下: LVGL Basics — LVGL documentation…...
HarmonyOs学习 环境配置后 实验1:创建项目Hello World
HarmonyOS开发入门:环境配置与Hello World实验 实验目标 掌握HarmonyOS开发环境配置,创建首个HarmonyOS应用并实现"Hello World"界面展示 实验准备 已安装DevEco Studio开发环境已配置HarmonyOS开发依赖项熟悉基本TypeScript/ArkTS语法&am…...
国产SMT贴片机自主技术突破解析
内容概要 随着电子信息产业对精密制造需求的持续升级,国产SMT贴片机的技术突破已成为装备自主化进程的关键节点。本文聚焦设备研发的三大核心领域:高动态运动控制系统通过线性电机与数字信号处理技术的融合,将重复定位精度提升至5μm级别&am…...
8、表单控制:预言水晶球——React 19 复杂表单处理
一、水晶球的预言本质 "每个表单都是时空裂缝中的预言容器,"占卜课教授特里劳妮凝视着水晶球,"React-Hook-Form与Formik的融合,让数据捕获如同捕捉未来碎片!" ——以魔法部神秘事务司的预言厅为隐喻…...
8 编程笔记全攻略:Markdown 语法精讲、Typora 编辑器全指南(含安装激活、基础配置、快捷键详解、使用技巧)
1 妙笔在手,编程无忧! 1.1 编程为啥要做笔记?这答案绝了! 嘿,各位键盘魔法师!学编程不记笔记,就像吃火锅不配冰可乐 —— 爽到一半直接噎住!你以为自己脑子是顶配 SSD,结…...
【MySQL】SQL语句在MySQL中的执行过程?主要存储引擎区别?
MySQL SQL语句执行过程详解 作为面试官,我来详细剖析一条SQL语句在MySQL中的完整执行过程,这是每个后端开发者都应该掌握的核心知识。 一、连接阶段 建立连接 客户端通过TCP/IP协议与MySQL服务器建立连接(默认3306端口)服务器验证用户名、密码和权限…...
Linux(autoDL云服务器)mamba-ssm环境安装——一次成功!
1.创建环境选择torch2.0, cuda11.8,python3.8 2.从GitHub官网下载cp38对应的,causl_conv1d,和mamba-ssm2.2.2。下载入下图所示。 3.直接用finalshell 或者xshell连接服务器上传,到根目录下面。 直接用pip install *…...
代码审计入门 原生态sql注入篇
前置知识: 漏洞形成的原因: 1、可控的参数 2、函数缺陷 代码审计的步骤: 1、全局使用正则搜索 漏洞函数 ,然后根据函数看变量是否可控,再看函数是否有过滤 2、根据web的功能点寻找函数,然后根据函数看…...
spring Ai---向量知识库(一)
在一些垂直领域以及公司内部信息相关或者实时性相关的大模型应用,就无法直接使用chatGPT。 这个时候,向量知识库就进入了。 通过坐标向量最接近的即为匹配相关答案。 向量模型定义:将文档向量化,保证内容越相似的文本,…...
jmeter利用csv进行参数化和自动断言
1.测试数据 csv测试数据如下(以注册接口为例) 2.jemer参数化csv设置 打开 jmeter,添加好线程组、HTTP信息头管理器、CSV 数据文件设置、注册请求、响应断言、查看结果树 1) CSV 数据文件设置 若 CSV 中数据包含中文,…...
C# 类型、存储和变量(数据成员和函数成员)
本章内容 C#程序是一组类型声明 类型是一种模板 实例化类型 数据成员和函数成员 预定义类型 用户定义类型 栈和堆 值类型和引用类型 变量 静态类型和dynamic关键字 可空类型 数据成员和函数成员 像short、int和long等这样的类型称为简单类型。这种类型只能存储一个数据项。 其…...
Java八种常见的设计模式
一、单例模式 单例模式是(Singleton Pattern)Java中最常用的设计模式之一,它保证一个类仅有一个实例,并提供一个全局访问点。 实现单例模式的核心是将类的构造方法私有化,以防止外部直接通过构造函数创建实例。同时&am…...
数据结构实验7.2:二叉树的基本运算
文章目录 一,实验目的二,问题描述三,基本要求四,实验操作五,示例代码六,运行效果 一,实验目的 深入理解树与二叉树的基本概念,包括节点、度、层次、深度等,清晰区分二叉…...
Go-zero框架修改模版进行handler统一响应封装
使用go-zero快速生成接口的时候,发现还是有一些情况不太好处理,比如说,想要自定义响应封装等等。 最开始第一版写api文件的时候,写法是这样的。 type LoginRequest {UserName string json:"userName"Password string …...
AI专题(一)----NLP2SQL探索以及解决方案
前面写了很多编码、算法、底层计算机原理等相关的技术专题,由于工作方向调整的缘故,今天开始切入AI人工智能相关介绍。本来按照规划,应该先从大模型的原理开始介绍会比较合适,但是计划赶不上变化,前面通用大模型的工作…...
深入理解 React Hooks:简化状态管理与副作用处理
在现代前端开发中,React 已经成为了最受欢迎的 JavaScript 库之一。随着 React 16.8 的发布,React Hooks 的引入彻底改变了开发者编写组件的方式。Hooks 提供了一种更简洁、更直观的方式来管理组件的状态和副作用,使得函数组件能够拥有类组件…...
Spring Boot 实现防盗链
在 Spring Boot 项目中实现防盗链可以通过多种方式,下面为你介绍两种常见的实现方法,分别是基于请求头 Referer 和基于令牌(Token)的防盗链。 基于请求头 Referer 的防盗链 这种方法通过检查请求头中的 Referer 字段,…...
Java 动态代理实现
Java 动态代理实现 一、JDK动态代理二、CGLIB动态代理三、动态代理的应用场景四、JDK代理与CGLIB代理比较 动态代理是Java中一种强大的技术,它允许在运行时创建代理对象,用于拦截对目标对象的方法调用。 一、JDK动态代理 JDK动态代理是Java标准库提供的代…...
2025年4月通信科技领域周报(4.07-4.13):6G技术加速落地 卫星通信网络迎来组网高潮
2025年4月通信科技领域周报(4.07-4.13):6G技术加速落地 卫星通信网络迎来组网高潮 目录 2025年4月通信科技领域周报(4.07-4.13):6G技术加速落地 卫星通信网络迎来组网高潮一、本周热点回顾1. 华为发布全球首…...
