热门标签 | HotTags
当前位置:  开发笔记 > Android > 正文

Android实现短信加密功能(发送加密短信、解密本地短信)

这篇文章主要介绍了android实现短信加密功能的相关资料,功能包括发送加密短信、解密本地短信,感兴趣的小伙伴们可以参考一下

短信加密此类功能由于新手学习的需求量较小,所以在网上很少有一些简单的demo供新手参考。小编做到此处也是花了比较多的时间自我构思,具体的过程也是不过多描述了,讲一下demo的内容。

 

 

 


demo功能:

1、可以发送短信并且加密(通过改变string中的char)

2、能够查看手机中的短信

3、能够给收到的加密短信解密。

涉及到的知识点:

1、intent bundle传递

2、ContentResolver获取手机短信

3、listveiw与simpleAdapter

4、发送短信以及为发送短信设置要监听的广播

遇到的问题:

1、发送短信字符过长会导致发送失败

解决方法:设置发送每条短信为70个字以内。

原理:每条短信限制160字符以内,每个汉字是2个字符。平时我们发送短信几乎不限长度,是因为一旦超过了单条短信的长度,手机会自动分多条发送,然后接收方分多条接收后整合在一起显示。

代码:


MainActivity:

import android.app.Activity; 
import android.content.Intent; 
import android.support.v7.app.AppCompatActivity; 
import android.os.Bundle; 
import android.view.View; 
import android.widget.Button; 
 
public class MainActivity extends Activity { 
 
 @Override 
 protected void onCreate(Bundle savedInstanceState) { 
 super.onCreate(savedInstanceState); 
 setContentView(R.layout.activity_main); 
 
 InitView(); 
 } 
 
 private void InitView() { 
 Button send=(Button)findViewById(R.id.bt_send); 
 Button receive=(Button)findViewById(R.id.bt_receive); 
 
 send.setOnClickListener(new View.OnClickListener() { 
  @Override 
  public void onClick(View view) { 
  Intent intent=new Intent(MainActivity.this,SendActivity.class); 
  startActivity(intent); 
  } 
 }); 
 
 receive.setOnClickListener(new View.OnClickListener() { 
  @Override 
  public void onClick(View view) { 
  Intent intent=new Intent(MainActivity.this,ReceiveActivity.class); 
  startActivity(intent); 
  } 
 }); 
 } 
} 

SendActivity:

import android.app.Activity; 
import android.app.PendingIntent; 
import android.content.BroadcastReceiver; 
import android.content.Context; 
import android.content.Intent; 
import android.content.IntentFilter; 
import android.os.Bundle; 
import android.telephony.SmsManager; 
import android.util.Log; 
import android.view.View; 
import android.widget.Button; 
import android.widget.EditText; 
import android.widget.Toast; 
 
/** 
 * Created by 佳佳 on 2015/12/21. 
 */ 
public class SendActivity extends Activity { 
 
 private IntentFilter sendFilter; 
 private SendStatusReceiver sendStatusReceiver; 
 
 @Override 
 protected void onCreate(Bundle savedInstanceState) { 
 super.onCreate(savedInstanceState); 
 setContentView(R.layout.activity_send); 
 
 InitView(); 
 } 
 
 private void InitView() { 
 Button cancel = (Button) findViewById(R.id.cancel_edit); 
 Button send = (Button) findViewById(R.id.send_edit); 
 final EditText phOne= (EditText) findViewById(R.id.phone_edit_text); 
 final EditText msgInput = (EditText) findViewById(R.id.content_edit_text); 
 
 //为发送短信设置要监听的广播 
 sendFilter = new IntentFilter(); 
 sendFilter.addAction("SENT_SMS_ACTION"); 
 sendStatusReceiver = new SendStatusReceiver(); 
 registerReceiver(sendStatusReceiver, sendFilter); 
 
 send.setOnClickListener(new View.OnClickListener() { 
  @Override 
  public void onClick(View v) { 
  Toast.makeText(SendActivity.this, "加密发送中,请稍后...", Toast.LENGTH_SHORT).show(); 
  //接收edittext中的内容,并且进行加密 
  //倘若char+8超出了表示范围,则把原字符发过去 
  String address = phone.getText().toString(); 
  String cOntent= msgInput.getText().toString(); 
  String cOntents= ""; 
  for (int i = 0; i 

ReceiveActivity:

import android.app.Activity; 
import android.content.Intent; 
import android.database.Cursor; 
import android.net.Uri; 
import android.os.Bundle; 
import android.util.Log; 
import android.view.View; 
import android.widget.AdapterView; 
import android.widget.ListView; 
import android.widget.SimpleAdapter; 
import android.widget.TextView; 
 
import java.text.SimpleDateFormat; 
import java.util.ArrayList; 
import java.util.Date; 
import java.util.HashMap; 
import java.util.List; 
import java.util.Map; 


public class ReceiveActivity extends Activity implements AdapterView.OnItemClickListener{ 
 private TextView Tv_address; 
 private TextView Tv_body; 
 private TextView Tv_time; 
 private ListView listview; 
 private List> dataList; 
 private SimpleAdapter simple_adapter; 
 
 @Override 
 protected void onCreate(Bundle savedInstanceState) { 
 super.onCreate(savedInstanceState); 
 setContentView(R.layout.activity_receive); 
 
 InitView(); 
 } 
 
 @Override 
 protected void onStart() { 
 super.onStart(); 
 RefreshList(); 
 } 
 
 
 private void InitView() { 
 Tv_address = (TextView) findViewById(R.id.tv_address); 
 Tv_body = (TextView) findViewById(R.id.tv_body); 
 Tv_time = (TextView) findViewById(R.id.tv_time); 
 listview = (ListView) findViewById(R.id.list_receive); 
 dataList = new ArrayList>(); 
 
 listview.setOnItemClickListener(this); 
 } 
 
 private void RefreshList() { 
 //从短信数据库读取信息 
 Uri uri = Uri.parse("content://sms/"); 
 String[] projection = new String[]{"address", "body", "date"}; 
 Cursor cursor = getContentResolver().query(uri, projection, null, null, "date desc"); 
 startManagingCursor(cursor); 
 
 //此处为了简化代码提高效率,仅仅显示20条最近短信 
 for (int i = 0; i <20; i++) { 
  //从手机短信数据库获取信息 
  if(cursor.moveToNext()) { 
  String address = cursor.getString(cursor.getColumnIndex("address")); 
  String body = cursor.getString(cursor.getColumnIndex("body")); 
  long lOngDate= cursor.getLong(cursor.getColumnIndex("date")); 
  //将获取到的时间转换为我们想要的方式 
  SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss"); 
  Date d = new Date(longDate); 
  String time = dateFormat.format(d); 
 
 
  Map map = new HashMap(); 
  map.put("address", address); 
  map.put("body", body+"body"); 
  map.put("time", time+" time"); 
  dataList.add(map); 
  } 
 } 
 
 simple_adapter = new SimpleAdapter(this, dataList, R.layout.activity_receive_list_item, 
  new String[]{"address", "body", "time"}, new int[]{ 
  R.id.tv_address, R.id.tv_body, R.id.tv_time}); 
 listview.setAdapter(simple_adapter); 
 } 
 
 @Override 
 public void onItemClick(AdapterView<&#63;> adapterView, View view, int i, long l) { 
 //获取listview中此个item中的内容 
 //content的内容格式如下 
 //{body=[B@43c2da70body, address=+8615671562394address, time=2015-12-24 11:55:50time} 
 String cOntent= listview.getItemAtPosition(i) + ""; 
 String body = content.substring(content.indexOf("body=") + 5, 
  content.indexOf("body,")); 
 //Log.i("hahaha",body); 
 String address = content.substring(content.indexOf("address=") + 8, 
  content.lastIndexOf(",")); 
 //Log.i("hahaha",address); 
 String time = content.substring(content.indexOf("time=") + 5, 
  content.indexOf(" time}")); 
 //Log.i("hahaha",time); 
 
 //使用bundle存储数据发送给下一个Activity 
 Intent intent=new Intent(ReceiveActivity.this,ReceiveActivity_show.class); 
 Bundle bundle = new Bundle(); 
 bundle.putString("body", body); 
 bundle.putString("address", address); 
 bundle.putString("time", time); 
 intent.putExtras(bundle); 
 startActivity(intent); 
 
 } 
} 

ReceiveActivity_show:

import android.app.Activity; 
import android.os.Bundle; 
import android.widget.TextView; 
 
public class ReceiveActivity_show extends Activity { 
 private TextView Address_show; 
 private TextView Time_show; 
 private TextView Early_body_show; 
 private TextView Late_body_show; 
 
 @Override 
 protected void onCreate(Bundle savedInstanceState) { 
 super.onCreate(savedInstanceState); 
 setContentView(R.layout.activity_receive_show); 
 
 InitView(); 
 } 
 
 private void InitView() { 
 
 Address_show = (TextView) findViewById(R.id.address_show); 
 Time_show = (TextView) findViewById(R.id.time_show); 
 Early_body_show = (TextView) findViewById(R.id.early_body_show); 
 Late_body_show = (TextView) findViewById(R.id.late_body_show); 
 
 //接收内容和id 
 Bundle bundle = this.getIntent().getExtras(); 
 String body = bundle.getString("body"); 
 String time = bundle.getString("time"); 
 String address = bundle.getString("address"); 
 
 
 Address_show.setText(address); 
 Early_body_show.setText(body); 
 Time_show.setText(time); 
 
 //对短信消息进行解密后显示在textview中 
 //倘若char+8超出了表示范围,则直接按照原字符解析 
 String real_cOntent= ""; 
 for (int i = 0; i 

activity_main:

<&#63;xml version="1.0" encoding="utf-8"&#63;> 
 
 
 
  
 

activity_send:

<&#63;xml version="1.0" encoding="utf-8"&#63;> 
 
 
 
 
  
 
  
 
  
 
  
 
  
 
  
 
  
 
  
 
  

activity_receive:

<&#63;xml version="1.0" encoding="utf-8"&#63;> 
 
 
  
 
  
 
 

activity_receive_show:

<&#63;xml version="1.0" encoding="utf-8"&#63;> 
 
 
 
  
 
  
 
  
 
   
 
   
  
 
  
 
   
 
   
  
 
  
 
   
 
   
  
 
  
 
   
 
   
  
 
 
  
 

以上就是本文的全部内容,android实现短信加密,实现发送加密短信、解密本地短信,希望对大家的学习有所帮助。


推荐阅读
  • Android 九宫格布局详解及实现:人人网应用示例
    本文深入探讨了人人网Android应用中独特的九宫格布局设计,解析其背后的GridView实现原理,并提供详细的代码示例。这种布局方式不仅美观大方,而且在现代Android应用中较为少见,值得开发者借鉴。 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • Android LED 数字字体的应用与实现
    本文介绍了一种适用于 Android 应用的 LED 数字字体(digital font),并详细描述了其在 UI 设计中的应用场景及其实现方法。这种字体常用于视频、广告倒计时等场景,能够增强视觉效果。 ... [详细]
  • RecyclerView初步学习(一)
    RecyclerView初步学习(一)ReCyclerView提供了一种插件式的编程模式,除了提供ViewHolder缓存模式,还可以自定义动画,分割符,布局样式,相比于传统的ListVi ... [详细]
  • 解决JAX-WS动态客户端工厂弃用问题并迁移到XFire
    在处理Java项目中的JAR包冲突时,我们遇到了JaxWsDynamicClientFactory被弃用的问题,并成功将其迁移到org.codehaus.xfire.client。本文详细介绍了这一过程及解决方案。 ... [详细]
  • 2023 ARM嵌入式系统全国技术巡讲旨在分享ARM公司在半导体知识产权(IP)领域的最新进展。作为全球领先的IP提供商,ARM在嵌入式处理器市场占据主导地位,其产品广泛应用于90%以上的嵌入式设备中。此次巡讲将邀请来自ARM、飞思卡尔以及华清远见教育集团的行业专家,共同探讨当前嵌入式系统的前沿技术和应用。 ... [详细]
  • Python自动化处理:从Word文档提取内容并生成带水印的PDF
    本文介绍如何利用Python实现从特定网站下载Word文档,去除水印并添加自定义水印,最终将文档转换为PDF格式。该方法适用于批量处理和自动化需求。 ... [详细]
  • 在当前众多持久层框架中,MyBatis(前身为iBatis)凭借其轻量级、易用性和对SQL的直接支持,成为许多开发者的首选。本文将详细探讨MyBatis的核心概念、设计理念及其优势。 ... [详细]
  • 将Web服务部署到Tomcat
    本文介绍了如何在JDeveloper 12c中创建一个Java项目,并将其打包为Web服务,然后部署到Tomcat服务器。内容涵盖从项目创建、编写Web服务代码、配置相关XML文件到最终的本地部署和验证。 ... [详细]
  • XNA 3.0 游戏编程:从 XML 文件加载数据
    本文介绍如何在 XNA 3.0 游戏项目中从 XML 文件加载数据。我们将探讨如何将 XML 数据序列化为二进制文件,并通过内容管道加载到游戏中。此外,还会涉及自定义类型读取器和写入器的实现。 ... [详细]
  • 本文介绍如何在 Unity 的 XML 配置文件中,将参数传递给自定义生命周期管理器的构造函数。我们将详细探讨 CustomLifetimeManager 类的实现及其配置方法。 ... [详细]
  • 本文详细介绍了 Java 中 org.apache.xmlbeans.SchemaType 类的 getBaseEnumType() 方法,提供了多个代码示例,并解释了其在不同场景下的使用方法。 ... [详细]
  • 本文详细介绍了如何解决MyBatis中常见的BindingException错误,提供了多种排查和修复方法,确保Mapper接口与XML文件的正确配置。 ... [详细]
  • 基于KVM的SRIOV直通配置及性能测试
    SRIOV介绍、VF直通配置,以及包转发率性能测试小慢哥的原创文章,欢迎转载目录?1.SRIOV介绍?2.环境说明?3.开启SRIOV?4.生成VF?5.VF ... [详细]
  • 本文探讨了在通过 API 端点调用时,使用猫鼬(Mongoose)的 findOne 方法总是返回 null 的问题,并提供了详细的解决方案和建议。 ... [详细]
author-avatar
印度神油两性a
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有