热门标签 | 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 listview OnItemClickListener失效原因
    最近在做listview时发现OnItemClickListener失效的问题,经过查找发现是因为button的原因。不仅listitem中存在button会影响OnItemClickListener事件的失效,还会导致单击后listview每个item的背景改变,使得item中的所有有关焦点的事件都失效。本文给出了一个范例来说明这种情况,并提供了解决方法。 ... [详细]
  • 本文讨论了Alink回归预测的不完善问题,指出目前主要针对Python做案例,对其他语言支持不足。同时介绍了pom.xml文件的基本结构和使用方法,以及Maven的相关知识。最后,对Alink回归预测的未来发展提出了期待。 ... [详细]
  • 本文讲述了如何通过代码在Android中更改Recycler视图项的背景颜色。通过在onBindViewHolder方法中设置条件判断,可以实现根据条件改变背景颜色的效果。同时,还介绍了如何修改底部边框颜色以及提供了RecyclerView Fragment layout.xml和项目布局文件的示例代码。 ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • 本文介绍了在SpringBoot中集成thymeleaf前端模版的配置步骤,包括在application.properties配置文件中添加thymeleaf的配置信息,引入thymeleaf的jar包,以及创建PageController并添加index方法。 ... [详细]
  • XML介绍与使用的概述及标签规则
    本文介绍了XML的基本概念和用途,包括XML的可扩展性和标签的自定义特性。同时还详细解释了XML标签的规则,包括标签的尖括号和合法标识符的组成,标签必须成对出现的原则以及特殊标签的使用方法。通过本文的阅读,读者可以对XML的基本知识有一个全面的了解。 ... [详细]
  • Java验证码——kaptcha的使用配置及样式
    本文介绍了如何使用kaptcha库来实现Java验证码的配置和样式设置,包括pom.xml的依赖配置和web.xml中servlet的配置。 ... [详细]
  • Android系统移植与调试之如何修改Android设备状态条上音量加减键在横竖屏切换的时候的显示于隐藏
    本文介绍了如何修改Android设备状态条上音量加减键在横竖屏切换时的显示与隐藏。通过修改系统文件system_bar.xml实现了该功能,并分享了解决思路和经验。 ... [详细]
  • 本文介绍了Android 7的学习笔记总结,包括最新的移动架构视频、大厂安卓面试真题和项目实战源码讲义。同时还分享了开源的完整内容,并提醒读者在使用FileProvider适配时要注意不同模块的AndroidManfiest.xml中配置的xml文件名必须不同,否则会出现问题。 ... [详细]
  • Android开发实现的计时器功能示例
    本文分享了Android开发实现的计时器功能示例,包括效果图、布局和按钮的使用。通过使用Chronometer控件,可以实现计时器功能。该示例适用于Android平台,供开发者参考。 ... [详细]
  • HDFS2.x新特性
    一、集群间数据拷贝scp实现两个远程主机之间的文件复制scp-rhello.txtroothadoop103:useratguiguhello.txt推pushscp-rr ... [详细]
  • flowable工作流 流程变量_信也科技工作流平台的技术实践
    1背景随着公司业务发展及内部业务流程诉求的增长,目前信息化系统不能够很好满足期望,主要体现如下:目前OA流程引擎无法满足企业特定业务流程需求,且移动端体 ... [详细]
  • 本文介绍了在使用MSXML解析XML文件时出现DTD禁用问题的解决方案。通过代码示例和错误信息获取方法,解释了默认情况下DTD是禁用的,以及如何启用DTD的方法。此外,还提到了网上关于该问题的信息相对较少,因此本文提供了解决方案以供参考。 ... [详细]
  • 在Xamarin XAML语言中如何在页面级别构建ControlTemplate控件模板
    本文介绍了在Xamarin XAML语言中如何在页面级别构建ControlTemplate控件模板的方法和步骤,包括将ResourceDictionary添加到页面中以及在ResourceDictionary中实现模板的构建。通过本文的阅读,读者可以了解到在Xamarin XAML语言中构建控件模板的具体操作步骤和语法形式。 ... [详细]
  • r2dbc配置多数据源
    R2dbc配置多数据源问题根据官网配置r2dbc连接mysql多数据源所遇到的问题pom配置可以参考官网,不过我这样配置会报错我并没有这样配置将以下内容添加到pom.xml文件d ... [详细]
author-avatar
安琪儿
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有