1、按键盘上的Windows按钮以打开“开始”菜单或“开始”屏幕。
2、搜索 cmd。在搜索结果列表中,右键单击命令提示符,然后单击以管理员身份运行。
3、显示“用户帐户控制”提示时,请单击是。
4、在命令提示符处,键入 powercfg -h on,然后按 Enter。
5、键入 exit,然后按 Enter 以关闭命令提示符窗口。
注:Win10关闭系统休眠后,会导致“快速启动”功能失效。
1、按键盘上的Windows按钮以打开“开始”菜单或“开始”屏幕。
2、搜索 cmd。在搜索结果列表中,右键单击命令提示符,然后单击以管理员身份运行。
3、显示“用户帐户控制”提示时,请单击是。
4、在命令提示符处,键入 powercfg -h on,然后按 Enter。
5、键入 exit,然后按 Enter 以关闭命令提示符窗口。
注:Win10关闭系统休眠后,会导致“快速启动”功能失效。
Android 中获取设备id一直是老生常谈的事情,先说下名词解释
今天我们先说一下获取deviceId的方法:
/** * 获取deviceId(手机唯一的标识) * * @param context * @return */ @SuppressLint({"HardwareIds"}) public static String getDeviceId(Context context) { String deviceId; if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.Q) { deviceId = Settings.Secure.getString(context.getContentResolver(), Settings.Secure.ANDROID_ID); } else { if (ActivityCompat.checkSelfPermission(context, Manifest.permission.READ_PHONE_STATE) != PackageManager.PERMISSION_GRANTED) { return ""; } TelephonyManager mTelephony = (TelephonyManager) context.getSystemService(TELEPHONY_SERVICE); if (mTelephony.getDeviceId() != null) { if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) { deviceId = mTelephony.getImei(); } else { deviceId = mTelephony.getDeviceId(); } } else { deviceId = Settings.Secure.getString(context.getContentResolver(), Settings.Secure.ANDROID_ID); } } return deviceId; }
转载自:下载apk并启动安装
本篇实现现在网络上的apk并启动安装程序。
写入权限和网络访问权限
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/> <uses-permission android:name="android.permission.INTERNET" />
private DownloadManager downloadManager = null; //下载管理器 private long mTaskId; // 任务id private String fileName; //下载下来文件保存时候的文件名称 fileName = System.currentTimeMillis() + ".apk"; downloadManager = (DownloadManager) getSystemService(Context.DOWNLOAD_SERVICE); String url = "http://111.202.99.13/imtt.dd.qq.com/16891/2A76B7A9A8E841F0D8C1E74AD65FCB3F.apk?mkey=57c3dd3fc5355f8e&f=6c25&c=0&fsname=com.tencent.mobileqq_6.5.3_398.apk&csr=4d5s&p=.apk"; downloadAPK(url);
上面代码调用了downloadAPK方法。
其中用到了文件保存位置,也可以使用缓存目录替换。
// 使用系统下载器下载 private void downloadAPK(String versionUrl) { // 创建下载任务 DownloadManager.Request request = new DownloadManager.Request( Uri.parse(versionUrl)); request.setAllowedOverRoaming(false);// 漫游网络是否可以下载 // 设置文件类型,可以在下载结束后自动打开该文件 MimeTypeMap mimeTypeMap = MimeTypeMap.getSingleton(); String mimeString = mimeTypeMap.getMimeTypeFromExtension(MimeTypeMap .getFileExtensionFromUrl(versionUrl)); request.setMimeType(mimeString); // 在通知栏中显示,默认就是显示的 request.setNotificationVisibility(DownloadManager.Request.VISIBILITY_VISIBLE); request.setVisibleInDownloadsUi(true); // sdcard的目录下的download文件夹,必须设置 request.setDestinationInExternalPublicDir("/download/", fileName); // request.setDestinationInExternalFilesDir(),也可以自己制定下载路径 // 将下载请求加入下载队列 downloadManager = (DownloadManager) getSystemService(Context.DOWNLOAD_SERVICE); // 加入下载队列后会给该任务返回一个long型的id, // 通过该id可以取消任务,重启任务等等 mTaskId = downloadManager.enqueue(request); // 注册广播接收者,监听下载状态 registerReceiver(receiver, new IntentFilter( DownloadManager.ACTION_DOWNLOAD_COMPLETE)); }
上面代码用到了receiver
// 广播接受者,接收下载状态 private BroadcastReceiver receiver = new BroadcastReceiver() { @Override public void onReceive(Context context, Intent intent) { checkDownloadStatus();// 检查下载状态 } }; // 检查下载状态 private void checkDownloadStatus() { DownloadManager.Query query = new DownloadManager.Query(); query.setFilterById(mTaskId);// 筛选下载任务,传入任务ID,可变参数 Cursor c = downloadManager.query(query); if (c.moveToFirst()) { int status = c.getInt(c .getColumnIndex(DownloadManager.COLUMN_STATUS)); switch (status) { case DownloadManager.STATUS_PAUSED: Log.i("download", ">>>下载暂停"); case DownloadManager.STATUS_PENDING: Log.i("download", ">>>下载延迟"); case DownloadManager.STATUS_RUNNING: Log.i("download", ">>>正在下载"); break; case DownloadManager.STATUS_SUCCESSFUL: Log.i("download", ">>>下载完成"); // 下载完成安装APK String downloadPath = Environment .getExternalStoragePublicDirectory( Environment.DIRECTORY_DOWNLOADS) .getAbsolutePath() + File.separator + fileName; installAPK(new File(downloadPath)); break; case DownloadManager.STATUS_FAILED: Log.e("download", ">>>下载失败"); break; } } }
上面代码用到了installAPK,作用是下载完成后开始安装。
// 下载到本地后执行安装 protected void installAPK(File file) { if (!file.exists()) return; Intent intent = new Intent(Intent.ACTION_VIEW); Uri uri = Uri.parse("file://" + file.toString()); intent.setDataAndType(uri, "application/vnd.android.package-archive"); intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK); startActivity(intent); }
如果要静默安装,上面的方法是不行的,设备必须root。可以参考这里
date
1.执行如下命令可以设置一个新的系统时间:
date -s "20220926 17:18:50"
2.设置完后还要执行如下命令保存一下设置:
hwclock --systohc
3.当然我们也可以将上面两个操作合二为一:
date -s "20220926 17:18:50" &&hwclock --systohc
转载自:Unity 打包安卓apk失败“Build-tool 31.0.0 is missing DX”或“Build-tool 32.0.0 is missing DX”
Build Tool 31 以后从SDK内删除了dx工具,使用d8工具来替代dx工具。
解决方法有:
转载自:VS与VC版本的对应关系
VC 版本 |
_MSC_VER |
VS 版本 |
MSVC toolset version |
---|---|---|---|
VC6.0 | 1200 | VS 6.0 | |
VC7.0 | 1300 | VS2002 | |
VC7.1 | 1310 | VS2003 | |
VC8.0 | 1400 | VS2005 | 80 |
VC9.0 | 1500 | VS2008 | 90 |
VC10.0 | 1600 | VS2010 | 100 |
VC11.0 | 1700 | VS2012 | 110 |
VC12.0 | 1800 | VS2013 | 120 |
VC14.0 | 1900 | VS2015 | 140 |
VC15.0 | [1910,1916] | VS2017 | 141 |
VC16.0 | [1920,1929] | VS2019 | 142 |
VC17.0 | [1930,) | VS2022 | 143 |
package top.gaojc.util; public class ButtonClickUtils { private static long lastClickTime;//记录最近一次点击时间 private static long interval = 1000;//间隔为1秒 private static int lastButtonId;//存放最近一次传入的按钮id // 如果需要不同的间隔时间,直接调用这个方法设置所需间隔毫秒数即可 public static void setInterval(long interval) { ButtonClickUtils.interval = interval; } // 不需要传入任何参数 直接在点击事件下调用此方法即可 public static boolean isFastClick() { if (System.currentTimeMillis() - lastClickTime < interval) { return true; } lastClickTime = System.currentTimeMillis(); return false; } // 需要传入ButtonId public static boolean isFastClick(int buttonId) { if (lastButtonId == buttonId && System.currentTimeMillis() - lastClickTime < interval) { return true; } lastClickTime = System.currentTimeMillis(); lastButtonId = buttonId; return false; } }
findViewById(R.id.submitButton).setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { // 防止重复点击 if (ButtonClickUtils.isFastClick()) { return; } // 后续操作 EventBus.getDefault().post(new RegisterEvent()); } });
项目地址:https://github.com/isilent-me/MQTT
参考项目:https://github.com/brandonbai/mqtt-spring-boot
订阅
mosquitto_sub -h localhost -t "test/#" -u hanmeimei -P 123456 -i "client1"
发布
mosquitto_pub -h localhost -t "test/abc" -u lilei -P 123456 -i "client3" -m "How are you?"
MQTT的定义相信很多人都能讲的头头是道,本文章也不讨论什么高大上的东西,旨在用最简单直观的方式让每一位刚接触的同行们可以最快的应用起来
先从使用MQTT需要什么开始分析:
根据上面列举的这三点,我们大概可以了解到, MQTT最适合的场景是消息做为系统的重要组成部分,且参与着系统关键业务逻辑的情形
既然决定使用它,我们首先要研究的是如何让MQTT正常工作,毕竟它不是简单的在maven里加入个依赖就完事的
我们总共需要干如下两件事:
<dependency> <groupId>org.springframework.integration</groupId> <artifactId>spring-integration-mqtt</artifactId> <version>5.3.2.RELEASE</version> </dependency>
完成上面两步后, 启动EMQX服务器, 正式进入我们的MQTT旅途
在Spring Boot中使用MQTT的代码, 笔者总结了如下两种方式:
第一种会产生一定程度的心智负担,但在笔者成功搭配(抄袭+造轮子)自动注册后, 比后者要方便许多
在介绍具体代码之前, 我们先简单整理下使用中最常见的概念:
其实, MQTT的使用流程就是: 生产者给主题发消息->broker进行消息的传递->订阅该主题的消费者拿到消息并进行相应的业务逻辑