android实时短信获取问题

android手机实时抓取其他手机发过来的短信,在模拟器上可以显示手机号码和信息内容,但是在真机上面测试就显示不了,有没有人做过相关的应用,希望能帮忙解决一下。

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
android获取短信的权限被拒绝了,怎么知道呢,版本低于android6.0
android获取短信的权限被拒绝了,怎么知道呢,版本低于android6.0
Android 端点击按钮从Java服务端获取短信验证,Android端的按钮如何计时
Android 端点击按钮从Java服务端获取短信验证,Android端的按钮如何计时
Android 接收短信功能
package com.example.smstest; import javax.security.auth.PrivateCredentialPermission; import android.os.Bundle; import android.app.Activity; import android.content.BroadcastReceiver; import android.content.Context; import android.content.Intent; import android.content.IntentFilter; import android.telephony.gsm.SmsMessage; import android.util.Log; import android.view.Menu; import android.widget.TextView; public class MainActivity extends Activity { private TextView sender; private TextView content; private IntentFilter receiveFilter; private MessageReceiver messageReceiver; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); sender=(TextView)findViewById(R.id.sender); content=(TextView)findViewById(R.id.content); receiveFilter=new IntentFilter(); Log.v("sss","success0"); receiveFilter.addAction("android.provider.Telephony.SMS_RECEIVED"); Log.v("sss","success1"); messageReceiver=new MessageReceiver(); Log.v("sss","success2"); registerReceiver(messageReceiver,receiveFilter); Log.v("sss","success3"); } class MessageReceiver extends BroadcastReceiver { @Override public void onReceive(Context context, Intent intent) { // TODO Auto-generated method stub Log.v("sss","success4"); Bundle bundle=intent.getExtras();//从intent中取出一个bundle对象 Object[] pdus=(Object[])bundle.get("pdus"); //提取短信消息使用pdus密钥提取一个SMS pdus数组; SmsMessage[] messages=new SmsMessage[pdus.length]; //将每一字节数组转换为SmsMessage对象 for(int i=0;i<messages.length;i++) { messages[i]=SmsMessage.createFromPdu((byte[])pdus[i]); } String address=messages[0].getOriginatingAddress(); //调用message对象的getOriginatingAddress()方法 //获取发送方号码; String fullMessage=" "; for(SmsMessage message: messages) { fullMessage+=message.getMessageBody();//获取短信内容将短信内容拼接起来 } sender.setText(address);//显示在TextView上 content.setText(fullMessage); } } @Override public boolean onCreateOptionsMenu(Menu menu) { // Inflate the menu; this adds items to the action bar if it is present. getMenuInflater().inflate(R.menu.main, menu); return true; } @Override protected void onDestroy() { // TODO Auto-generated method stub super.onDestroy(); unregisterReceiver(messageReceiver); } }
Android如何通过获取信用卡账单,短信中有不止一家银行
服务器返回给我某家银行,短信里面有多家银行,如何获取服务器需要的银行账单
关于android4.4以后短信监听的问题
大家好,我最近在做一个短信监听的项目,要能够监听和删除短信。由于android4.4以后短信数据库需要设置为默认短信应用才能有写操作,我是用了一台魅族手做的测试,广播方式无法监听到短信的到来,数据库观察者也无法获取,但是我发现360手机卫士那个隐私空间却可以在魅族手机监听短信,并且不让短信显示在短信列表里。我想请问下,那么360是通过哪种方式监听到的呢?请大神指点一下。
android获取短信内容时,总是收到两次短信内容
public String getSmsAndSendBack() { String[] projection = new String[] { "address", "person", "body" }; StringBuilder str = new StringBuilder(); try { ContentResolver cr = getContentResolver(); Cursor myCursor = cr.query(Uri.parse("content://sms/inbox"), projection, "address = ?", new String[] { "+86"+number}, "date desc"); str.append(processResults(myCursor, true)); } catch (SQLiteException ex) { // Log.d(LOG_TAG, ex.getMessage()); } return str.toString(); } /** * * 处理短信结果 * * @param cur * * @param all * 用来判断是读一条还是全部读。后来没有用all,可以无视 */ private StringBuilder processResults(Cursor cur, boolean all) { StringBuilder str = new StringBuilder(); if (cur.moveToFirst()) { String name; String phoneNumber; String sms = null; int nameColumn = cur.getColumnIndex("person"); int phoneColumn = cur.getColumnIndex("address"); int smsColumn = cur.getColumnIndex("body"); // do { name = cur.getString(nameColumn); phoneNumber = cur.getString(phoneColumn); if (phoneNumber.equals("+86"+number)) { sms = cur.getString(smsColumn); str.append(sms); } if (null == sms) sms = ""; // } while (cur.moveToNext()); } else { str.append("no result!"); } return str; } ![图片说明](https://img-ask.csdn.net/upload/201505/24/1432472589_284704.png)
Android如何获取listview里面的选取的数据
需要在lv1.setOnItemLongClickListener方法中加入一个长按获取电话号码,联系人的代码,我写的代码总感觉有错误,但是不知道错在哪,我尝试用system输出我获取的数值,数值是对的,但是传不到打电话和发短信的地方 ![图片说明](https://img-ask.csdn.net/upload/201512/27/1451222337_132249.png) 这是效果图 package com.example.lianxi; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; import java.util.zip.Inflater; import android.R.string; import android.app.Activity; import android.app.ActionBar; import android.app.Fragment; import android.content.Intent; import android.net.Uri; import android.os.Bundle; import android.view.ContextMenu; import android.view.LayoutInflater; import android.view.Menu; import android.view.MenuInflater; import android.view.MenuItem; import android.view.View; import android.view.ViewGroup; import android.view.ContextMenu.ContextMenuInfo; import android.widget.AdapterView; import android.widget.AdapterView.OnItemLongClickListener; import android.widget.ArrayAdapter; import android.widget.ListView; import android.widget.SimpleAdapter; import android.widget.Toast; import android.os.Build; public class M1 extends Activity { private ListView lv1; private int[] pic = new int[] { R.drawable.img01, R.drawable.img02, R.drawable.img03, R.drawable.img04, }; private String[] xm = new String[] { "张三", "李四", "王五", "赵六" }; private String[] dh = new String[] { "626746", "624882", "620874", "130533", }; String s = ""; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.m1); lv1 = (ListView) findViewById(R.id.lv1); final List<Map<String, Object>> list = new ArrayList<Map<String, Object>>(); for (int i = 0; i < pic.length; i++) { Map<String, Object> m1 = new HashMap<String, Object>(); m1.put("pic", pic[i]); m1.put("xm", xm[i]); m1.put("dh", dh[i]); list.add(m1); } SimpleAdapter sa = new SimpleAdapter(M1.this, list, R.layout.moban, new String[] { "pic", "xm", "dh" }, new int[] { R.id.iv1, R.id.tv1, R.id.tv2 }); lv1.setAdapter(sa); lv1.setOnItemLongClickListener(new OnItemLongClickListener() { @Override public boolean onItemLongClick(AdapterView<?> arg0, View arg1, int arg2, long arg3) { HashMap<String, Object> map = (HashMap<String, Object>) lv1 .getItemAtPosition(arg2); String xm = String.valueOf(map.get("xm").toString()); String dh = String.valueOf(map.get("dh").toString()); System.out.println(xm); System.out.println(dh); return false; } }); registerForContextMenu(lv1); } @Override public void onCreateContextMenu(ContextMenu menu, View v, ContextMenuInfo menuInfo) { // TODO Auto-generated method stub MenuInflater m1 = new MenuInflater(M1.this); m1.inflate(R.menu.m1, menu); menu.setHeaderIcon(R.drawable.i); menu.setHeaderTitle("请选择"); super.onCreateContextMenu(menu, v, menuInfo); } @Override public boolean onContextItemSelected(MenuItem item) { // TODO Auto-generated method stub switch (item.getItemId()) { case R.id.dh: Intent intent = new Intent(); intent.setAction(intent.ACTION_CALL); intent.setData(Uri.parse("tel:" + dh)); startActivity(intent); break; case R.id.dx: Intent intent1 = new Intent(); intent1.setAction(intent1.ACTION_SENDTO); intent1.setData(Uri.parse("smsto:" + dh)); intent1.putExtra("sms_body", ""); startActivity(intent1); break; } return super.onContextItemSelected(item); } }
调用Android系统将短信发送出去
Uri smsToUri = Uri.parse("smsto:"+ num); //获取电话号码 //调用系统短信发送界面,写入发送对象 Intent intent = new Intent(Intent.ACTION_SENDTO, smsToUri); intent.putExtra("sms_body", content);//短信发送界面内容写入 startActivity(intent);//调用Android系统 这个方法可以将短信发送对象和内容均传送到系统短信界面,但是没有直接发送出去 PendingIntent pi=PendingIntent.getBroadcast(MainActivity.this, 0, new Intent(), 0); sm.sendTextMessage(num, null, text, pi, null); 这个可以直接发送短信,但是不能将短信内容直接发送内容显示在系统的短信发送界面。 请问各位大神,有没有一种方法,指定短信发送对象和内容,然后可以将短信直接发送出去的? 谢谢!
Android如何扫描获取二维码中的数据?
我首先做了一个二维码名片,把信息输入进去以后生成了一个二维码,现在需要通过扫描这个二维码获取里面的信息中的电话号码信息,然后是一个发短信的过程。现在的问题就是如何扫描获得这个电话号码?
安卓 获取手机号码代码
现在版本的系统是不是不能用getLine1Number 获取到了。还可以通过手机短信获取,此方法有人验证过吗?
安卓开发关于通过广播获取信息的问题
申请权限 <uses-permission android:name="android.permission.RECEIVE_SMS"/> <!--短信广播监听器--> <receiver android:name=".Broadcast"> <intent-filter android:priority="999"> <action android:name="android.provider.Telephony.SMS_RECEIVED" /> </intent-filter> </receiver> import android.content.BroadcastReceiver; import android.content.Context; import android.content.Intent; import android.os.Bundle; import android.os.Message; import android.telephony.SmsMessage; import android.widget.Toast; public class Broadcast extends BroadcastReceiver { private static final String ACTION="android.provider.Telephony.SMS_RECEIVED"; private Message message=new Message(); private Bundle bundle=new Bundle(); @Override public void onReceive(Context context, Intent intent){ Toast.makeText(context, "来短信啦",Toast.LENGTH_SHORT).show(); if(ACTION.equals(intent.getAction())){ SmsMessage[] smsMessage=getMessageFromIntent(intent); StringBuilder str=new StringBuilder(); if(smsMessage!=null&&smsMessage.length>0){ for(SmsMessage smg:smsMessage){ str.append(smg.getDisplayOriginatingAddress()+":\n "); str.append(smg.getDisplayMessageBody()+"\n"); } } Toast.makeText(context, str.toString(),Toast.LENGTH_SHORT).show(); } } public static SmsMessage[] getMessageFromIntent(Intent intent){ SmsMessage[] smsMessage=null; Bundle bundle=intent.getExtras(); Object[] puds=(Object[])bundle.get("puds"); smsMessage=new SmsMessage[puds.length]; for(int i=0;i<puds.length;i++){ byte[] data=((byte[])puds[i]); smsMessage[i]=SmsMessage.createFromPdu(data); } return smsMessage; } } 请问哪里错了就是监听不了短信,有人发短信来没app没反应 不好意思我小白一个没有C币,求助
Android 关于服务里面的AsyncTask方法问题
最近,小弟在写一个拦截短信的android 程序,在开启拦截服务这个地方被卡了好几天了, 换了好几种思路,最后参考一种网上的思路用了AsyncTask这种思路。 但是运行程序的时候报错,但是不太清楚哪里出错了,求大神帮看一看服务的这个包。 ``` public class MsgService extends Service{ private boolean D=true; private ReceiveMessage mReceiver; @Override public IBinder onBind(Intent intent) { // TODO Auto-generated method stub return null; } @Override public void onCreate() { if(D){ Log.i("msgservice"," onCreate()"); } //注册动态广播 mReceiver=new ReceiveMessage(); IntentFilter filter=new IntentFilter(); filter.setPriority(Integer.MAX_VALUE); filter.addAction("android.provider.Telephony.SMS_RECEIVED"); registerReceiver(mReceiver, filter); super.onCreate(); } @Override public int onStartCommand(Intent intent, int flags, int startId) { if(D){ Log.i("msgservice","onStartCommand"); } return super.onStartCommand(intent, flags, startId); } @Override public void onDestroy() { if(D){ Log.i("msgservice","onDestroy() "); } //取消广播接收者 unregisterReceiver(mReceiver); mReceiver=null; super.onDestroy(); } class ReceiveMessage extends BroadcastReceiver { private String address; private String fullMessage; private MyDatabaseHelper dbHelper; // 当接收到短息时被触发 @Override public void onReceive(Context context, Intent intent) { Bundle bundle = intent.getExtras(); // 判断是否有数据 if (bundle != null) { // 通过pdus可以获得接收到的所有短信消息 Object[] pdus = (Object[]) bundle.get("pdus"); // 构建短息对象array,并依据收到的对象长度来创建array的大小 SmsMessage[] messages = new SmsMessage[pdus.length]; for (int i = 0; i < pdus.length; i++) { messages[i] = SmsMessage.createFromPdu((byte[]) pdus[i]); } address = messages[0].getOriginatingAddress();//获取发送方号码 fullMessage = ""; for (SmsMessage message : messages) { fullMessage +=message.getMessageBody();//获取短信内容 } new AsyncTask<Void,Void,Void>(){ @Override protected Void doInBackground(Void... params) { return null; } @Override protected void onPostExecute(Void result) { if(fullMessage.startsWith("Test")||fullMessage.endsWith("Test"))//发现短信,拦截,并且存入数据库 { abortBroadcast(); // 取消广播(这行代码将会让系统接受短信程序收不到短息) //入库要从新写,用AsyncTask new AsyncTask<Void,Void,Void>(){ @Override protected Void doInBackground(Void... params) { //把陌生人短信存储在数据库表里 SQLiteDatabase db = dbHelper.getWritableDatabase(); ContentValues values = new ContentValues(); values.put("phonenumber",address); values.put("content",fullMessage); db.insert("TEXT", null, values); return null; } }.execute(); } super.onPostExecute(result); } }.execute(); } } } } ``` 在发送一个拦截开头为Test的短息的时候,报错如图: ![图片说明](https://img-ask.csdn.net/upload/201602/17/1455721145_244228.png) ![图片说明](https://img-ask.csdn.net/upload/201602/17/1455721098_338520.png)
Android 使用Post带参数方法请求获取服务器响应,确未收到验证码短信
如下是点击事件: ``` public void onClick(View v) { //生成6位随机数 int num = (int) ((Math.random() * 9 + 1) * 100000); String[] Contents = new String[5]; Contents[0]="CorpID="+"duanyuntao"; //账号 必填 Contents[1]="Pwd="+"123456"; //密码 必填 Contents[2]="Cell="+"null"; // 选填 Contents[3]="Mobile="+"15565651713"; // 这里填写个固定号码做测试, Contents[4]="Content="+"【验证码】信息,您的验证码为:"+num; //验证码信息本地生成,作为参数上传 String url="http://101.200.29.88:8082/SendMT/SendMessage"; HttpUtil.sendHttpRequestPost(url,Contents,new HttpCallbackListener() { @Override public void onFinish(String response){ Log.d("TAG","finish"); } @Override public void onError(Exception e){ e.printStackTrace(); Log.d("TAG","error"); } } ); } }); ``` 网络请求: ``` public static void sendHttpRequestPost(final String address,final String[] content,final HttpCallbackListener listener ){ new Thread(new Runnable() { @Override public void run() { HttpURLConnection connection = null; try { URL url = new URL(address); connection = (HttpURLConnection) url .openConnection(); connection.setConnectTimeout(8000); connection.setRequestMethod("POST"); // connection.setRequestProperty("Charset", "UTF-8"); connection.setReadTimeout(8000); connection.setDoInput(true); DataOutputStream outputStream = new DataOutputStream(connection.getOutputStream()); String Content = content[0]+"&"+content[1]+"&"+content[2]+"&"+content[3]+"&"+content[4]; outputStream.write(Content.getBytes()); outputStream.flush(); outputStream.close(); InputStream in = connection.getInputStream(); BufferedReader reader = new BufferedReader(new InputStreamReader(in)); StringBuilder response = new StringBuilder(); String line; while ((line=reader.readLine())!=null ){ response.append(line); } if(listener != null){ listener.onFinish(response.toString()); //成功回调 } }catch (Exception e) { if (listener != null) { listener.onError(e);//失败回调 } e.printStackTrace(); } } }).start(); } ``` 接口文档 如下图: ![图片说明](https://img-ask.csdn.net/upload/201610/08/1475934556_310365.png) ![图片说明](https://img-ask.csdn.net/upload/201610/08/1475934568_221844.png)
美丽说android端的一键注册是怎样实现的?
看到了美丽说有个一键注册的功能,感觉很方便,就是用户在android客户端上只需要点击一键注册的按钮,就可以直接注册用户,比同于传统模式填写手机好发送验证码,填写验证码,填写密码要简单的多,但是对于这个功能,我不知道小弟的思路是否正确,忘各位大侠多多指点。 一键注册我感觉其实和传统的注册方式大致相同,都是依赖于手机号作为账号的,而一键注册将填写手机号的过程交由程序后台来完成。首先要知道注册用户的当前手机号,但是现在大部分的手机卡都是无法直接获取手机号的,所以在点击一键注册的时候,会发现系统会提示要发送一条短信,我认为,是向服务器端发送了一条短信,这条短信可能什么内容都没有,服务器端的短息平台只需要能获得发送短信的短信号码就可以作为用户注册的账户,然后在通过推送告诉这个手机用户的后台服务器已经接受到了注册申请,申请成功就由服务器端自动分配一个登录密码
一个可以读取短信的app为什么收到短信之后没有效果
public class MainActivity extends Activity { private TextView sender; private TextView content; private IntentFilter receiveFilter; private MessageReceiver messageReceiver; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); sender=(TextView)findViewById(R.id.sender); content=(TextView)findViewById(R.id.content); receiveFilter=new IntentFilter(); receiveFilter.addAction("android.provider.Telephony.SMS_RECEIVED"); messageReceiver=new MessageReceiver(); registerReceiver(messageReceiver,receiveFilter); } class MessageReceiver extends BroadcastReceiver { @Override public void onReceive(Context context, Intent intent) { // TODO Auto-generated method stub Bundle bundle=intent.getExtras();//从intent中取出一个bundle对象 Object[] pdus=(Object[])bundle.get("pdus"); //提取短信消息使用pdus密钥提取一个SMS pdus数组; SmsMessage[] messages=new SmsMessage[pdus.length]; //将每一字节数组转换为SmsMessage对象 for(int i=0;i<messages.length;i++) { messages[i]=SmsMessage.createFromPdu((byte[])pdus[i]); } String address=messages[0].getOriginatingAddress(); //调用message对象的getOriginatingAddress()方法 //获取发送方号码; String fullMessage=" "; for(SmsMessage message: messages) { fullMessage+=message.getMessageBody();//获取短信内容将短信内容拼接起来 } sender.setText(address);//显示在TextView上 content.setText(fullMessage); } } @Override public boolean onCreateOptionsMenu(Menu menu) { // Inflate the menu; this adds items to the action bar if it is present. getMenuInflater().inflate(R.menu.main, menu); return true; } @Override protected void onDestroy() { // TODO Auto-generated method stub super.onDestroy(); unregisterReceiver(messageReceiver); } } 使用广播接收器接收广播来读取短信的内容显示在Textview里为什么程序没有效果
小白求教 android中listview的点击冲突问题
刚才写了一段代码 想通过点击listview上每一项的imageview删除数据库中对应的这一条数据, 但运行时每次都必须点击两下imageview才能删除这一项,之前想过在listview的适配器中来做这个 操作,但是看过的代码好像都没有这么做过并且这样做的话没法更新数据,现在想问问 有没有什么好的方法可以解决这个问题 。对了,设置focusable和clickable属性也没法处理。设置成imagebutton的话 , 由于listview的每一项是通过反射来获取到的 给imagebutton设置onclick属性的话 ,数据就没法传递了,毕竟还是要删除数据库中的数据 ```package com.personal.fyd.blacknumber; import android.content.Context; import android.util.Log; import android.view.View; import android.view.ViewGroup; import android.widget.BaseAdapter; import android.widget.ImageButton; import android.widget.ImageView; import android.widget.TextView; import java.util.List; /** * Created by asus on 2016/10/19. */ public class MyAdapter extends BaseAdapter { private List<NumberBean> list; private Context context; public MyAdapter(List<NumberBean> list, Context context) { this.list = list; this.context = context; // for (NumberBean bean:list // ) { // Log.i(context+"",bean.getNumber()+" "+bean.getMode()); // } } @Override public int getCount() { return list.size(); } @Override public Object getItem(int position) { return list.get(position); } @Override public long getItemId(int position) { return 0; } @Override public View getView(int position, View convertView, ViewGroup parent) { ViewHolder viewHolder; NumberBean bean; if (convertView == null) { convertView = View.inflate(context, R.layout.item, null); viewHolder = new ViewHolder(); viewHolder.number_tv = (TextView) convertView.findViewById(R.id.tv_number); viewHolder.mode_tv = (TextView) convertView.findViewById(R.id.tv_mode); viewHolder.delete_iv = (ImageView) convertView.findViewById(R.id.iv_delete); convertView.setTag(viewHolder); }else { viewHolder = (ViewHolder) convertView.getTag(); } bean = list.get(position); viewHolder.number_tv.setText(bean.getNumber()); String mode = bean.getMode(); if ("1".equals(mode)){ viewHolder.mode_tv.setText("电话拦截"); }else if ("2".equals(mode)){ viewHolder.mode_tv.setText("短信拦截"); }else if ("3".equals(mode)){ viewHolder.mode_tv.setText("全部拦截"); } return convertView; } static class ViewHolder { TextView number_tv; TextView mode_tv; ImageView delete_iv; } } ``` package com.personal.fyd.blacknumber; import android.content.Context; import android.support.v7.app.AlertDialog; import android.support.v7.app.AppCompatActivity; import android.os.Bundle; import android.text.TextUtils; import android.view.View; import android.widget.AdapterView; import android.widget.Button; import android.widget.CheckBox; import android.widget.EditText; import android.widget.ImageView; import android.widget.ListView; import android.widget.Toast; import java.util.List; public class MainActivity extends AppCompatActivity { private final Context context = MainActivity.this; private ListView lv; private AlertDialog alertDialog; private NumberDao numberdao; private MyAdapter adapter; private List<NumberBean> list; private ImageView iv; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); initView(); updateLV(); } private void updateLV() { list = numberdao.findAll(); adapter = new MyAdapter(list,MainActivity.this); lv.setAdapter(adapter); } private void initView() { lv = (ListView) findViewById(R.id.lv); numberdao = new NumberDao(this); iv = (ImageView) findViewById(R.id.iv_delete); lv.setOnItemClickListener(new AdapterView.OnItemClickListener() { @Override public void onItemClick(AdapterView<?> parent, View view, final int position, long id) { Toast.makeText(context,"再次点击删除此项",Toast.LENGTH_SHORT).show(); view.findViewById(R.id.iv_delete).setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { String num = list.get(position).getNumber(); // Toast.makeText(context,num,Toast.LENGTH_SHORT).show(); numberdao.delete(num); numberdao.findAll(); updateLV(); } }); } }); } public void delete(View view){ } public void add(View view){ showDiagle(); } //显示对话框 private void showDiagle(){ AlertDialog.Builder builder = new AlertDialog.Builder(this); View view = View.inflate(this,R.layout.diagle,null); builder.setView(view); final EditText editText = (EditText) view.findViewById(R.id.blacknumber_et); final CheckBox call_cb = (CheckBox) view.findViewById(R.id.call_cb); final CheckBox sms_cb = (CheckBox) view.findViewById(R.id.sms_cb); Button commit = (Button) view.findViewById(R.id.commit_btn); Button cancel = (Button)view.findViewById(R.id.cancel_btn); commit.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { String number = editText.getText().toString(); //判断是否为空 if (TextUtils.isEmpty(number)){ Toast.makeText(MainActivity.this,"number ",Toast.LENGTH_SHORT).show(); return; } String mode; if (call_cb.isChecked()&&sms_cb.isChecked()){ mode = "3"; }else if (call_cb.isChecked()){ mode = "1"; }else if (sms_cb.isChecked()){ mode = "2"; }else { Toast.makeText(MainActivity.this,"请至少选择一种拦截方式",Toast.LENGTH_SHORT).show(); return; } //操作合法 插入数据 numberdao.insert(number,mode); //插入成功 重新查询 alertDialog.dismiss(); updateLV(); } }); cancel.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { alertDialog.dismiss(); } }); alertDialog = builder.create(); alertDialog.show(); } } ``` ```
android开发mob平台的smssdk验证问题
最近在做一个短信登录的功能,成功获取验证码后,给按钮绑定监听器,点击事件发生时验证验证码是否正确,核心的代码就是“ sms.comp如果areSMScode(telenumber,smscode);” 如果正确,mob的服务器会返回手机号和国家代码,否则返回false 问题出现在下面的的代码,我第一次点击按钮之后,返回的是false,然后再点击一次按钮才返回号码和国家,问题到底出在哪里呢?? ``` mobileLoginIn.setOnClickListener(new View.OnClickListener(){ @Override public void onClick(View v) { String telenumber=telePhoneIn.getText().toString(); String smscode=SMScode.getText().toString(); sms.compareSMScode(telenumber,smscode); if(sms.ismatched==true){ Toast.makeText(LoginWithMobile.this,"验证成功",Toast.LENGTH_LONG).show(); boolean ifexist=false; // boolean ifFirstLogin =false; // if(ifexist){ if(ifFirstLogin){ // }else{ // } }else{ // } } else{ Toast.makeText(LoginWithMobile.this,"验证失败"+sms.consolecompareSMScode,Toast.LENGTH_LONG).show(); } sms.consolecompareSMScode=""; sms.ismatched=false; sms.compareSMScodeEventHandler=null; } }); ```
Android 语音识别— 怎么做到 先识别打电话,再识别电话号码?
由于刚学Android开发, 所以有些功能还是不知道怎么去实现。 我想按按钮实现语音输入,然后识别, 如果我说“打电话”,标志位signal为"打电话"。 然后再点识别按钮的时候,就读取我说的电话号码“tel_num”, 然后就直接把这个号码打出去了。 我是想实现这个功能,但是我不熟悉Android的执行方式, 到真机上就强制关闭,我一直没找到解决办法, 求前辈指点,谢了。 代码如下: public void onClick(View v) { if(v.getId()==R.id.btn) { /*启动手机内置的语言识别功能*/ Intent intent = new Intent(RecognizerIntent.ACTION_RECOGNIZE_SPEECH); intent.putExtra(RecognizerIntent.EXTRA_LANGUAGE_MODEL, RecognizerIntent.LANGUAGE_MODEL_FREE_FORM); //设置为当前手机的语言类型 intent.putExtra(RecognizerIntent.EXTRA_PROMPT, "请说话,我识别");//出现语言识别界面上面需要显示的提示 startActivityForResult(intent,REQUEST_CODE); if(signal.equal("打电话")){call(tel_num);} } } protected void onActivityResult(int requestCode, int resultCode, Intent data) { /* 回调获取从谷歌得到的数据*/ if(requestCode==REQUEST_CODE&&resultCode==RESULT_OK) { List<String> list = data.getStringArrayListExtra(RecognizerIntent.EXTRA_RESULTS); listView.setAdapter(new ArrayAdapter<String>(this,android.R.layout.simple_list_item_1,list)); //把数据显示在listview中 Iterator<String> it = list.iterator(); while (it.hasNext()) { if(it.next().equals("打电话")){signal=new String("打电话");break;} if(it.next().equals("发短信")){signal=new String("发短信");break;} } tel_num=list.get(0); } super.onActivityResult(requestCode, resultCode, data); } public void call(String num){ Intent dia1 = new Intent(); dia1.setAction("android.intent.action.CALL"); dia1.setData(Uri.parse("tel://"+num)); startActivity(dia1); }
content://sms/对应mmssms中的哪张表
Android的中,在使用系统的ContentProvider获取短信数据时,content://sms/对应mmssms中的哪张表?
终于明白阿里百度这样的大公司,为什么面试经常拿ThreadLocal考验求职者了
点击上面↑「爱开发」关注我们每晚10点,捕获技术思考和创业资源洞察什么是ThreadLocalThreadLocal是一个本地线程副本变量工具类,各个线程都拥有一份线程私...
《奇巧淫技》系列-python!!每天早上八点自动发送天气预报邮件到QQ邮箱
将代码部署服务器,每日早上定时获取到天气数据,并发送到邮箱。 也可以说是一个小人工智障。 思路可以运用在不同地方,主要介绍的是思路。
加快推动区块链技术和产业创新发展,2019可信区块链峰会在京召开
11月8日,由中国信息通信研究院、中国通信标准化协会、中国互联网协会、可信区块链推进计划联合主办,科技行者协办的2019可信区块链峰会将在北京悠唐皇冠假日酒店开幕。   区块链技术被认为是继蒸汽机、电力、互联网之后,下一代颠覆性的核心技术。如果说蒸汽机释放了人类的生产力,电力解决了人类基本的生活需求,互联网彻底改变了信息传递的方式,区块链作为构造信任的技术有重要的价值。   1...
阿里面试官问我:如何设计秒杀系统?我的回答让他比起大拇指
你知道的越多,你不知道的越多 点赞再看,养成习惯 GitHub上已经开源 https://github.com/JavaFamily 有一线大厂面试点脑图和个人联系方式,欢迎Star和指教 前言 Redis在互联网技术存储方面使用如此广泛,几乎所有的后端技术面试官都要在Redis的使用和原理方面对小伙伴们进行360°的刁难。 作为一个在互联网公司面一次拿一次Offer的面霸,打败了...
C语言魔塔游戏
很早就很想写这个,今天终于写完了。 游戏截图: 编译环境: VS2017 游戏需要一些图片,如果有想要的或者对游戏有什么看法的可以加我的QQ 2985486630 讨论,如果暂时没有回应,可以在博客下方留言,到时候我会看到。 下面我来介绍一下游戏的主要功能和实现方式 首先是玩家的定义,使用结构体,这个名字是可以自己改变的 struct gamerole { char n...
面试官问我:什么是消息队列?什么场景需要他?用了会出现什么问题?
你知道的越多,你不知道的越多 点赞再看,养成习惯 GitHub上已经开源 https://github.com/JavaFamily 有一线大厂面试点脑图、个人联系方式和人才交流群,欢迎Star和完善 前言 消息队列在互联网技术存储方面使用如此广泛,几乎所有的后端技术面试官都要在消息队列的使用和原理方面对小伙伴们进行360°的刁难。 作为一个在互联网公司面一次拿一次Offer的面霸...
Android性能优化(4):UI渲染机制以及优化
文章目录1. 渲染机制分析1.1 渲染机制1.2 卡顿现象1.3 内存抖动2. 渲染优化方式2.1 过度绘制优化2.1.1 Show GPU overdraw2.1.2 Profile GPU Rendering2.2 卡顿优化2.2.1 SysTrace2.2.2 TraceView 在从Android 6.0源码的角度剖析View的绘制原理一文中,我们了解到View的绘制流程有三个步骤,即m...
微服务中的Kafka与Micronaut
今天,我们将通过Apache Kafka主题构建一些彼此异步通信的微服务。我们使用Micronaut框架,它为与Kafka集成提供专门的库。让我们简要介绍一下示例系统的体系结构。我们有四个微型服务:订单服务,行程服务,司机服务和乘客服务。这些应用程序的实现非常简单。它们都有内存存储,并连接到同一个Kafka实例。 我们系统的主要目标是为客户安排行程。订单服务应用程序还充当网关。它接收来自客户的请求...
致 Python 初学者们!
作者| 许向武 责编 | 屠敏 出品 | CSDN 博客 前言 在 Python 进阶的过程中,相信很多同学应该大致上学习了很多 Python 的基础知识,也正在努力成长。在此期间,一定遇到了很多的困惑,对未来的学习方向感到迷茫。我非常理解你们所面临的处境。我从2007年开始接触 Python 这门编程语言,从2009年开始单一使用 Python 应对所有的开发工作,直至今...
究竟你适不适合买Mac?
我清晰的记得,刚买的macbook pro回到家,开机后第一件事情,就是上了淘宝网,花了500元钱,找了一个上门维修电脑的师傅,上门给我装了一个windows系统。。。。。。 表砍我。。。 当时买mac的初衷,只是想要个固态硬盘的笔记本,用来运行一些复杂的扑克软件。而看了当时所有的SSD笔记本后,最终决定,还是买个好(xiong)看(da)的。 已经有好几个朋友问我mba怎么样了,所以今天尽量客观...
程序员一般通过什么途径接私活?
二哥,你好,我想知道一般程序猿都如何接私活,我也想接,能告诉我一些方法吗? 上面是一个读者“烦不烦”问我的一个问题。其实不止是“烦不烦”,还有很多读者问过我类似这样的问题。 我接的私活不算多,挣到的钱也没有多少,加起来不到 20W。说实话,这个数目说出来我是有点心虚的,毕竟太少了,大家轻喷。但我想,恰好配得上“一般程序员”这个称号啊。毕竟苍蝇再小也是肉,我也算是有经验的人了。 唾弃接私活、做外...
字节跳动面试官这样问消息队列:分布式事务、重复消费、顺序消费,我整理了一下
你知道的越多,你不知道的越多 点赞再看,养成习惯 GitHub上已经开源 https://github.com/JavaFamily 有一线大厂面试点脑图、个人联系方式和人才交流群,欢迎Star和完善 前言 消息队列在互联网技术存储方面使用如此广泛,几乎所有的后端技术面试官都要在消息队列的使用和原理方面对小伙伴们进行360°的刁难。 作为一个在互联网公司面一次拿一次Offer的面霸...
Python爬虫爬取淘宝,京东商品信息
小编是一个理科生,不善长说一些废话。简单介绍下原理然后直接上代码。 使用的工具(Python+pycharm2019.3+selenium+xpath+chromedriver)其中要使用pycharm也可以私聊我selenium是一个框架可以通过pip下载 pip installselenium -ihttps://pypi.tuna.tsinghua.edu.cn/simple/ ...
阿里程序员写了一个新手都写不出的低级bug,被骂惨了。
这种新手都不会范的错,居然被一个工作好几年的小伙子写出来,差点被当场开除了。
Java工作4年来应聘要16K最后没要,细节如下。。。
前奏: 今天2B哥和大家分享一位前几天面试的一位应聘者,工作4年26岁,统招本科。 以下就是他的简历和面试情况。 基本情况: 专业技能: 1、&nbsp;熟悉Sping了解SpringMVC、SpringBoot、Mybatis等框架、了解SpringCloud微服务 2、&nbsp;熟悉常用项目管理工具:SVN、GIT、MAVEN、Jenkins 3、&nbsp;熟悉Nginx、tomca...
SpringBoot2.x系列教程(三十六)SpringBoot之Tomcat配置
Spring Boot默认内嵌的Tomcat为Servlet容器,关于Tomcat的所有属性都在ServerProperties配置类中。同时,也可以实现一些接口来自定义内嵌Servlet容器和内嵌Tomcat等的配置。 关于此配置,网络上有大量的资料,但都是基于SpringBoot1.5.x版本,并不适合当前最新版本。本文将带大家了解一下最新版本的使用。 ServerProperties的部分源...
Python绘图,圣诞树,花,爱心 | Turtle篇
每周每日,分享Python实战代码,入门资料,进阶资料,基础语法,爬虫,数据分析,web网站,机器学习,深度学习等等。 公众号回复【进群】沟通交流吧,QQ扫码进群学习吧 微信群 QQ群 1.画圣诞树 import turtle screen = turtle.Screen() screen.setup(800,600) circle = turtle.Turtle()...
作为一个程序员,CPU的这些硬核知识你必须会!
CPU对每个程序员来说,是个既熟悉又陌生的东西? 如果你只知道CPU是中央处理器的话,那可能对你并没有什么用,那么作为程序员的我们,必须要搞懂的就是CPU这家伙是如何运行的,尤其要搞懂它里面的寄存器是怎么一回事,因为这将让你从底层明白程序的运行机制。 随我一起,来好好认识下CPU这货吧 把CPU掰开来看 对于CPU来说,我们首先就要搞明白它是怎么回事,也就是它的内部构造,当然,CPU那么牛的一个东...
破14亿,Python分析我国存在哪些人口危机!
一、背景 二、爬取数据 三、数据分析 1、总人口 2、男女人口比例 3、人口城镇化 4、人口增长率 5、人口老化(抚养比) 6、各省人口 7、世界人口 四、遇到的问题 遇到的问题 1、数据分页,需要获取从1949-2018年数据,观察到有近20年参数:LAST20,由此推测获取近70年的参数可设置为:LAST70 2、2019年数据没有放上去,可以手动添加上去 3、将数据进行 行列转换 4、列名...
听说想当黑客的都玩过这个Monyer游戏(1~14攻略)
第零关 进入传送门开始第0关(游戏链接) 请点击链接进入第1关: 连接在左边→ ←连接在右边 看不到啊。。。。(只能看到一堆大佬做完的留名,也能看到菜鸡的我,在后面~~) 直接fn+f12吧 &lt;span&gt;连接在左边→&lt;/span&gt; &lt;a href="first.php"&gt;&lt;/a&gt; &lt;span&gt;←连接在右边&lt;/span&gt; o...
在家远程办公效率低?那你一定要收好这个「在家办公」神器!
相信大家都已经收到国务院延长春节假期的消息,接下来,在家远程办公可能将会持续一段时间。 但是问题来了。远程办公不是人在电脑前就当坐班了,相反,对于沟通效率,文件协作,以及信息安全都有着极高的要求。有着非常多的挑战,比如: 1在异地互相不见面的会议上,如何提高沟通效率? 2文件之间的来往反馈如何做到及时性?如何保证信息安全? 3如何规划安排每天工作,以及如何进行成果验收? ...... ...
作为一个程序员,内存和磁盘的这些事情,你不得不知道啊!!!
截止目前,我已经分享了如下几篇文章: 一个程序在计算机中是如何运行的?超级干货!!! 作为一个程序员,CPU的这些硬核知识你必须会! 作为一个程序员,内存的这些硬核知识你必须懂! 这些知识可以说是我们之前都不太重视的基础知识,可能大家在上大学的时候都学习过了,但是嘞,当时由于老师讲解的没那么有趣,又加上这些知识本身就比较枯燥,所以嘞,大家当初几乎等于没学。 再说啦,学习这些,也看不出来有什么用啊!...
这个世界上人真的分三六九等,你信吗?
偶然间,在知乎上看到一个问题 一时间,勾起了我深深的回忆。 以前在厂里打过两次工,做过家教,干过辅导班,做过中介。零下几度的晚上,贴过广告,满脸、满手地长冻疮。 再回首那段岁月,虽然苦,但让我学会了坚持和忍耐。让我明白了,在这个世界上,无论环境多么的恶劣,只要心存希望,星星之火,亦可燎原。 下文是原回答,希望能对你能有所启发。 如果我说,这个世界上人真的分三六九等,...
2020年全新Java学习路线图,含配套视频,学完即为中级Java程序员!!
新的一年来临,突如其来的疫情打破了平静的生活! 在家的你是否很无聊,如果无聊就来学习吧! 世上只有一种投资只赚不赔,那就是学习!!! 传智播客于2020年升级了Java学习线路图,硬核升级,免费放送! 学完你就是中级程序员,能更快一步找到工作! 一、Java基础 JavaSE基础是Java中级程序员的起点,是帮助你从小白到懂得编程的必经之路。 在Java基础板块中有6个子模块的学...
B 站上有哪些很好的学习资源?
哇说起B站,在小九眼里就是宝藏般的存在,放年假宅在家时一天刷6、7个小时不在话下,更别提今年的跨年晚会,我简直是跪着看完的!! 最早大家聚在在B站是为了追番,再后来我在上面刷欧美新歌和漂亮小姐姐的舞蹈视频,最近两年我和周围的朋友们已经把B站当作学习教室了,而且学习成本还免费,真是个励志的好平台ヽ(.◕ฺˇд ˇ◕ฺ;)ノ 下面我们就来盘点一下B站上优质的学习资源: 综合类 Oeasy: 综合...
爬取薅羊毛网站百度云资源
这是疫情期间无聊做的爬虫, 去获取暂时用不上的教程 import threading import time import pandas as pd import requests import re from threading import Thread, Lock # import urllib.request as request # req=urllib.request.Requ...
如何优雅地打印一个Java对象?
你好呀,我是沉默王二,一个和黄家驹一样身高,和刘德华一样颜值的程序员。虽然已经写了十多年的 Java 代码,但仍然觉得自己是个菜鸟(请允许我惭愧一下)。 在一个月黑风高的夜晚,我思前想后,觉得再也不能这么蹉跎下去了。于是痛下决心,准备通过输出的方式倒逼输入,以此来修炼自己的内功,从而进阶成为一名真正意义上的大神。与此同时,希望这些文章能够帮助到更多的读者,让大家在学习的路上不再寂寞、空虚和冷。 ...
雷火神山直播超两亿,Web播放器事件监听是怎么实现的?
Web播放器解决了在手机浏览器和PC浏览器上播放音视频数据的问题,让视音频内容可以不依赖用户安装App,就能进行播放以及在社交平台进行传播。在视频业务大数据平台中,播放数据的统计分析非常重要,所以Web播放器在使用过程中,需要对其内部的数据进行收集并上报至服务端,此时,就需要对发生在其内部的一些播放行为进行事件监听。 那么Web播放器事件监听是怎么实现的呢? 01 监听事件明细表 名...
3万字总结,Mysql优化之精髓
本文知识点较多,篇幅较长,请耐心学习 MySQL已经成为时下关系型数据库产品的中坚力量,备受互联网大厂的青睐,出门面试想进BAT,想拿高工资,不会点MySQL优化知识,拿offer的成功率会大大下降。 为什么要优化 系统的吞吐量瓶颈往往出现在数据库的访问速度上 随着应用程序的运行,数据库的中的数据会越来越多,处理时间会相应变慢 数据是存放在磁盘上的,读写速度无法和内存相比 如何优化 设计...
HTML5适合的情人节礼物有纪念日期功能
前言 利用HTML5,css,js实现爱心树 以及 纪念日期的功能 网页有播放音乐功能 以及打字倾诉感情的画面,非常适合情人节送给女朋友 具体的HTML代码 具体只要修改代码里面的男某某和女某某 文字段也可自行修改,还有代码下半部分的JS代码需要修改一下起始日期 注意月份为0~11月 也就是月份需要减一。 当然只有一部分HTML和JS代码不够运行的,文章最下面还附加了完整代码的下载地址 &lt;!...
相关热词 c# 识别回车 c#生成条形码ean13 c#子控制器调用父控制器 c# 写大文件 c# 浏览pdf c#获取桌面图标的句柄 c# list反射 c# 句柄 进程 c# 倒计时 线程 c# 窗体背景色
立即提问