html 调用手机发短信功能语句

html 调用手机发短信功能语句,第1张

html 调用手机发短信功能语句如下:

1、建立短信模板

2、html页面加入以下代码:

<form action="servlet/Sim_servlet?action=SendSms" method="post">

电话号码:<input type="text" name="mobile">

内容:<input type="text" name="message">

<input type="submit" name="submit" value="提交">

</form>

3、后台通过短信模板处理:

String mobile=request.getParameter("mobile")

String message1=request.getParameter("message")

String message=java.net.URLEncoder.encode(message1)

String action=request.getParameter("action")

String pw="xxx"//私人密码

String ID="xxx"//用户id

String URL="http://www.72dns.com/smsadmin/Sms_Api.aspx?"

String last=URL+"UserID="+ID+"&PassWord="+pw+"&mobile="+mobile+"&message="+message+"&action="+action

response.sendRedirect(last)

在做一个微信的微网站中的一个便民服务电话功能的应用,用到移动web页面中列出的电话号码,点击需要实现调用通讯录,网页一键拨号的拨打电话功能。

如果需要在移动浏览器中实现拨打电话,发送email,美国服务器,调用sns等功能,移动手机WEB页面(HTML5)Javascript提供的接口是一个好办法。

采用url链接的方式,实现在Safari ios,香港服务器,Android 浏览器,webos 浏览器,塞班浏览器,IE,Operamini等主流浏览器,进行拨打电话功能。

1.最常用WEB页面JS实现一键拨号的电话拨打功能:

<a href="tel:(电话号码)">移动WEB页面JS一键拨打号码咨询功能</a>

在拨号界面,显示号码,并提示拨打。支持大部分的浏览器,但是在QQ浏览器上支持不好。

2.最常用WEB页面JS实现一键发送短信功能:

<a href="sms:(电话号码)">移动WEB页面JS一键发送短信咨询功能</a>

在信息录入界面,显示发送号码,并提示录入信息。

支持大部分的浏览器,但是在QQ浏览器上支持不好。

3、移动web页面自动探测电话号码

<meta name="format-detection" content="telephone=no">

<meta http-equiv="x-rim-auto-match" content="none">

4.使用wtai协议进行拨打电话。

代码如下所示:

实例:

<a href="wtai://wp//mc(电话号码)">拨打10086 </a> <a href="wtai://wp/ap(电话号码)">将10086存储至电话簿 </a>

建议采用这个方式。

5、不太灵验的方式:

<a href="dc:(电话号码)">移动WEB页面JS一键拨打号码咨询功能</a>

经过测试,大部分浏览器都不支持了。

最近采用phonegap做一个APP,需要在应用内实现拨打电话,通话结束後能反馈通话相关状态,查看了一番phonegap官方文档,似乎没有跟电话相关的api,在互联网上也大概搜了一下,好像没找到相关的内容。其实html5是支持直接在网页上拨打电话的,只要加入如下html代码即可:

[html] view plaincopy

打电话<a href="tel:10086" >移动客服</a>

发短信<a href="sms:10086" >发短信</a>

但这中方式只能实现拨打电话和发送短信,不能反馈结果,比如我想在应用能实现拨打电话,通话结束後自动保存通话的电话号码、通话时间、时长等,默认的html功能就不能满足了。

phonegap官方不提供的功能,我们只有自己通过开发插件了实现了

下面我们通过代码来简单介绍下phonegap插件开发步骤:

一、定义JS插件API

[javascript] view plaincopy

var Phone = function() {

}

Phone.prototype.call = function (successCallback, failureCallback,number) {

cordova.exec(successCallback, failureCallback, "Phone", "call", [number])

}

window.Phone = new Phone()

上面的代码我们定义了一个Phone插件,插件有一个call API,我们传入

[javascript] view plaincopy

successCallback

failureCallback

分别做为电话拨打成功和失败的回调函数

传入

[javascript] view plaincopy

number

做为电话号码

在方法裏边调用

phonegap的cordova.exec()

[javascript] view plaincopy

cordova.exec(successCallback, failureCallback, "Phone", "call", [number])

就是在这个方法裏将执行到native端的功能调用

最後我们new一个Phone对象,把他附件到window对象上,方便以後调用。

这样,插件的JS代码完成。

二、native端代码(以android平台为例)

先直接上代码

[java] view plaincopy

package com.juhuibao.PhoneGapPlugin

import java.util.Date

import org.apache.cordova.api.CallbackContext

import org.apache.cordova.api.CordovaPlugin

import org.apache.cordova.api.PluginResult

import org.json.JSONArray

import org.json.JSONException

import android.app.Activity

import android.content.Intent

import android.database.Cursor

import android.net.Uri

import android.provider.CallLog.Calls

import android.telephony.PhoneNumberUtils

public class Phone extends CordovaPlugin {

private static final int PHONE_CALL = 0// 拨打电话

private static final int PHONE_ABORT = 1// 挂断电话

private Date start_time

private CallbackContext callbackContext

private String phonenumber

@Override

public boolean execute(String action, JSONArray args, CallbackContext callbackContext) throws JSONException {

try{

this.callbackContext = callbackContext

if ("call".equals(action)) {

this.phonenumber=args.getString(0)

this.call(args.getString(0),callbackContext)

return true

}

if ("abort".equals(action)) {

this.abort(callbackContext)

return true

}

return false

}

catch(Exception e){

callbackContext.error(e.getMessage())

}

return false

}

//拨打电话

private void call(String phonenumber, CallbackContext callbackContext) {

if (phonenumber != null &&phonenumber.length() >0) {

if(PhoneNumberUtils.isGlobalPhoneNumber(phonenumber)){

Intent i = new Intent()

i.setAction(Intent.ACTION_CALL)

i.setData(Uri.parse("tel:"+phonenumber))

start_time=new Date()

this.cordova.startActivityForResult(this, i,PHONE_CALL)

}

else{

callbackContext.error(phonenumber+"不是有效的电话号码。")

}

} else {

callbackContext.error("电话号码不能为空.")

}

}

//中断电话

private void abort(CallbackContext callbackContext) {

}

public void onActivityResult(int requestCode, int resultCode, Intent intent) {

Date end_time=new Date()

if (resultCode == Activity.RESULT_OK) {

if (requestCode == PHONE_CALL) {

this.callbackContext.error("未知状态")

}

}

else if (resultCode == Activity.RESULT_CANCELED) {

try{

if (requestCode == PHONE_CALL) {

long duration=GetLastCallDuration()

PhoneResult result=new PhoneResult()

result.setNumber(Phone.this.phonenumber)

result.setStartTime(Phone.this.start_time)

result.setEndTime(end_time)

result.setDuration(duration)

this.callbackContext.sendPluginResult(new PluginResult(PluginResult.Status.OK, result.toJSONObject()))

}

}

catch(Exception e){

this.callbackContext.error(e.getMessage())

}

}

else {

this.callbackContext.error("其他错误!")

}

}

long delayTime=0

long timeOut=2000

long GetLastCallDuration() throws InterruptedException{

Activity activity = this.cordova.getActivity()

Cursor cursor = activity.getContentResolver().query(Calls.CONTENT_URI,

new String[] {Calls.NUMBER,Calls.DATE, Calls.DURATION, Calls.TYPE, Calls.DATE },

"number=?and type=?",

new String[]{this.phonenumber,"2"},

Calls.DEFAULT_SORT_ORDER)

activity.startManagingCursor(cursor)

boolean hasRecord = cursor.moveToFirst()

if (hasRecord) {

long endTime=cursor.getLong(cursor.getColumnIndex(Calls.DATE))

Date date = new Date(endTime)

long duration = cursor.getLong(cursor.getColumnIndex(Calls.DURATION))

long dif=this.start_time.getTime()-date.getTime()

long second=dif/1000

if(second<2&&second>-2){

return duration

}else{

if(delayTime>=timeOut){

return 0

}

Thread.sleep(200)

delayTime+=200

return GetLastCallDuration()

}

}else{

if(delayTime>=timeOut){

return 0

}

Thread.sleep(200)

delayTime+=200

return GetLastCallDuration()

}

}

}

然後调用具体实现拨打电话功能的方法call方法,在call方法内我们首先判断电话号码合法性,不合法直接调用callbackContext.error("不是有效的电话号码。"),这个方法将触发JS端的error回调函数执行,并传入一个字符串参数,比如以上的failureCallback

如果电话号码合法则d出呼叫界面,如下代码

[java] view plaincopy

if(PhoneNumberUtils.isGlobalPhoneNumber(phonenumber)){

Intent i = new Intent()

i.setAction(Intent.ACTION_CALL)

i.setData(Uri.parse("tel:"+phonenumber))

start_time=new Date()

this.cordova.startActivityForResult(this, i,PHONE_CALL)

}

else{

callbackContext.error(phonenumber+"不是有效的电话号码。")

}

在代码中我们通过变量start_time记录开始时间,然後使用this.cordova.startActivityForResult(this, i,PHONE_CALL)启动Activity。

在终止拨号或挂断电话时将执行onActivityResult方法,我们将在此方法内实现通话状态信息的反馈。主要看一下这段代码

[java] view plaincopy

else if (resultCode == Activity.RESULT_CANCELED) {

try{

if (requestCode == PHONE_CALL) {

long duration=GetLastCallDuration()

PhoneResult result=new PhoneResult()

result.setNumber(Phone.this.phonenumber)

result.setStartTime(Phone.this.start_time)

result.setEndTime(end_time)

result.setDuration(duration)

this.callbackContext.sendPluginResult(new PluginResult(PluginResult.Status.OK, result.toJSONObject()))

}

}

catch(Exception e){

this.callbackContext.error(e.getMessage())

}

}

不管电话有没有接通,resultCode总是等於Activity.RESULT_CANCELED。

我们通过GetLastCallDuration()方法获得通话时长,原理就是读取通话记录裏边的duration字段,由於通话刚结束时通话记录可能还没出现记录,所以我们要反复调用该方法,直到有记录或到超时时间为止。

取得了时长我们通过this.callbackContext.sendPluginResult(new PluginResult(PluginResult.Status.OK, result.toJSONObject()))把结果反馈给JS端。

附 PhoneResult.java

[java] view plaincopy

package com.juhuibao.PhoneGapPlugin

import java.text.SimpleDateFormat

import java.util.Date

import org.json.JSONException

import org.json.JSONObject

public class PhoneResult {

private String number = ""

private Date startTime

private Date endTime

private long duration = 0

public JSONObject toJSONObject() throws JSONException {

SimpleDateFormat sdf = new SimpleDateFormat("yyyy/MM/dd HH:mm:ss:S")

return new JSONObject(

"{number:" + JSONObject.quote(number) +

",startTime:" + JSONObject.quote(sdf.format(startTime)) +

",endTime:" + JSONObject.quote(sdf.format(endTime)) +

",duration:" + duration + "}")

}

public String getNumber() {

return number

}

public void setNumber(String number) {

this.number = number

}

public Date getStartTime() {

return startTime

}

public void setStartTime(Date startTime) {

this.startTime = startTime

}

public Date getEndTime() {

return endTime

}

public void setEndTime(Date endTime) {

this.endTime = endTime

}

public long getDuration() {

return duration

}

public void setDuration(long duration) {

this.duration = duration

}

}

这样native端的代码完成。

三、客户端调用

[javascript] view plaincopy

window.Phone.call(function (obj) { alert(JSON.stringify(obj))

}, function (err) { alert(err)}, "13401100000")

四、配置插件

在config.xml文件中注册插件

[html] view plaincopy

<plugin name="Phone" value="com.juhuibao.PhoneGapPlugin.Phone"/>

在AndroidManifest.xml文件中增加权限

[html] view plaincopy

<uses-permission android:name="android.permission.CALL_PHONE" />

<uses-permission android:name="android.permission.READ_CALL_LOG" />

<uses-permission android:name="android.permission.PROCESS_OUTGOING_CALLS" />

<uses-permission android:name="android.permission.READ_PHONE_STATE"/>


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/zaji/6112664.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-15
下一篇 2023-03-15

发表评论

登录后才能评论

评论列表(0条)

保存