高端响应式模板免费下载

响应式网页设计、开放源代码、永久使用、不限域名、不限使用次数

什么是响应式网页设计?

网页在线客服聊天软件(必备)3篇

2024年网页在线客服聊天软件 篇1

可以添加百度商桥代码,设置在线客服通过注册百度商桥账户,复制代码粘贴网站后台

2024年网页在线客服聊天软件 篇2

1,首先自己下载工具,搭建一个Android开发环境,去百度一下(安卓开发环境搭建),有详细步骤。

2,百度搜索“图灵机器人”,去注册一个账号,获取api key,用来调用图灵机器人的数据。2

把API key 复制下来放在一个记事本,之后要在代码中用的。3

先新建一个Android工程,我的工程名为:Person,源代码在com.shenbin.person包下,MainActivity是Android的activity。

还包括HttpDate类,HttpGetDateListener类,ListDate类,TextAdapter类

//MainActivity代码:

/*下面的代码修改

httpDate = (HttpDate) new HttpDate("http://www.tuling123.com/openapi/api?key=********&info=" +droph,this).execute();

把********替换成自己的API key

*/

package com.shenbin.person;

import java.text.SimpleDateFormat;import java.util.ArrayList;import java.util.Date;import java.util.List;

import org.json.JSONException;import org.json.JSONObject;

import android.os.Bundle;import android.app.Activity;import android.view.View;import android.view.View.OnClickListener;import android.widget.Button;import android.widget.EditText;import android.widget.ListView;

public class MainActivity extends Activity implements HttpGetDateListener,OnClickListener{ //实现接口

private HttpDate httpDate; private List<ListDate> lists; private ListView lv; private EditText getText; private Button send_btn; private String content_str; private TextAdapter adapter; private String [] welcome_array; private double currentTime,oldTime = 0; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); initView(); //httpDate = (HttpDate) new HttpDate("http://www.tuling123.com/openapi/api?key=5692c0d167fc5a180d092efaab578617&info=你好", //this).execute(); }

private void initView() { lv = (ListView) findViewById(R.id.lv); getText = (EditText) findViewById(R.id.sendText); send_btn = (Button) findViewById(R.id.send_btn); //send_btn.setOnClickListener((android.view.View.OnClickListener) this); send_btn.setOnClickListener(this); lists = new ArrayList<ListDate>(); adapter = new TextAdapter(lists, this); lv.setAdapter(adapter); ListDate listDate = null ; listDate = new ListDate(getRandomWelcomeTips(),listDate.RECEIVER,getTime()); lists.add(listDate);

} private String getRandomWelcomeTips() { String welcome_tip = null; welcome_array = this.getResources().getStringArray(R.array.welcome_tips); //获得string。xml的欢迎语 int index = (int) (Math.random()*(welcome_array.length-1)); welcome_tip = welcome_array[index]; return welcome_tip; } @Override public void getDateUrl(String date) { // TODO 自动生成的方法存根 //System.out.println(date); parseText(date); } public void parseText(String str) { try { JSONObject jb = new JSONObject(str); //System.out.println(jb.getString("code")); //System.out.println(jb.getString("text")); ListDate listDate = null; listDate = new ListDate(jb.getString("text"),listDate.RECEIVER,getTime()); lists.add(listDate); adapter.notifyDataSetChanged(); } catch (JSONException e) { // TODO 自动生成的 catch 块 e.printStackTrace(); } }

@Override public void onClick(View v) { getTime(); content_str = getText.getText().toString(); getText.setText(""); String dropk = content_str.replace(" ", ""); String droph = dropk.replace("\n", ""); ListDate listDate; listDate = new ListDate(content_str,ListDate.SEND,getTime()); lists.add(listDate); //如果太多了,就移除一些 if (lists.size() > 30) { for (int i = 0; i < lists.size(); i++) { lists.remove(i); } } adapter.notifyDataSetChanged(); httpDate = (HttpDate) new HttpDate("http://www.tuling123.com/openapi/api?key=********&info=" +droph,this).execute();

} private String getTime() { currentTime = System.currentTimeMillis(); SimpleDateFormat format = new SimpleDateFormat("yyyy年MM月dd日 HH:mm:ss"); Date curDate = new Date(); String str = format.format(curDate); if (currentTime - oldTime > 5*60*1000) { oldTime = currentTime; return str; }else { return ""; } }

}

//HttpDate类代码

package com.shenbin.person;

import java.io.BufferedReader;import java.io.InputStream;import java.io.InputStreamReader;

import org.apache.http.HttpEntity;import org.apache.http.HttpResponse;import org.apache.http.client.HttpClient;import org.apache.http.client.methods.HttpGet;import org.apache.http.impl.client.DefaultHttpClient;import android.os.AsyncTask;

public class HttpDate extends AsyncTask<String, Void, String>{ private HttpClient mHttpClient; //客户端 private HttpGet mHttpGet; //请求方式为get private String url; //请求的地址 private HttpResponse mHttpResponse; //请求返还 private HttpEntity mHttpEntity; //创建实体 private InputStream in; private HttpGetDateListener listener; //获得接口

public HttpDate(String url,HttpGetDateListener listener) { this.url = url; this.listener = listener; } @Override protected String doInBackground(String... arg0) { // TODO 自动生成的方法存根 try { mHttpClient = new DefaultHttpClient(); //实例化客户端 mHttpGet = new HttpGet(url); mHttpResponse = mHttpClient.execute(mHttpGet); mHttpEntity = mHttpResponse.getEntity(); in = mHttpEntity.getContent(); BufferedReader br = new BufferedReader(new InputStreamReader(in)); String line = null; //获取数据 StringBuffer sb = new StringBuffer(); while (( line = br.readLine()) != null) { sb.append(line); } return sb.toString(); } catch (Exception e) { // TODO: handle exception } return null; } @Override protected void onPostExecute(String result) { // TODO 自动生成的方法存根 listener.getDateUrl(result); super.onPostExecute(result); }

}

//HttpGetDateListener类代码

//接口

package com.shenbin.person;

public interface HttpGetDateListener {

void getDateUrl(String date);}

//ListDate类代码

package com.shenbin.person;

import android.R.integer;

public class ListDate { private String content; public static final int SEND = 1; public static final int RECEIVER = 2; private int flag; private String time; public ListDate(String content,int flag,String time) { // TODO 自动生成的构造函数存根 setContent(content); setFlag(flag); setTime(time); } public void setContent(String content) { this.content = content; }

public String getContent() { return content; }

public int getFlag() { return flag; }

public void setFlag(int flag) { this.flag = flag; }

public String getTime() { return time; }

public void setTime(String time) { this.time = time; }

}

//TextAdapter类代码

package com.shenbin.person;

import java.net.ContentHandler;import java.util.List;

import javax.security.auth.PrivateCredentialPermission;

import android.R.layout;import android.content.Context;import android.view.LayoutInflater;import android.view.View;import android.view.ViewGroup;import android.webkit.WebView.FindListener;import android.widget.BaseAdapter;import android.widget.RelativeLayout;import android.widget.TextView;

public class TextAdapter extends BaseAdapter{ private List<ListDate> lists; private Context nContext; private RelativeLayout layout; public TextAdapter(List<ListDate> lists,Context nContext) { this.lists = lists; this.nContext = nContext; }

@Override public int getCount() { // TODO 自动生成的方法存根 return lists.size(); }

@Override public Object getItem(int pesition) { return lists.get(pesition); }

@Override public long getItemId(int pesition) { // TODO 自动生成的方法存根 return pesition; }

@Override public View getView(int pesition, View converView , ViewGroup parent) { LayoutInflater inflater = LayoutInflater.from(nContext); if (lists.get(pesition).getFlag() == ListDate.RECEIVER) { layout = (RelativeLayout) inflater.inflate(R.layout.leftitem, null); } if (lists.get(pesition).getFlag() == ListDate.SEND) { layout = (RelativeLayout) inflater.inflate(R.layout.rightitem, null); } TextView tv = (TextView) layout.findViewById(R.id.tv); tv.setText(lists.get(pesition).getContent()); TextView time = (TextView) layout.findViewById(R.id.time); time.setText(lists.get(pesition).getTime()); return layout; }

}

activity_main.xml的代码:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="fill_parent" android:layout_height="fill_parent" android:orientation="vertical" android:paddingBottom="@dimen/activity_vertical_margin" android:paddingLeft="@dimen/activity_horizontal_margin" android:paddingRight="@dimen/activity_horizontal_margin" android:paddingTop="@dimen/activity_vertical_margin" tools:context=".MainActivity" >

<ListView android:id="@+id/lv" android:layout_width="fill_parent" android:layout_height="0dp" android:layout_weight="1" android:divider="@null" android:listSelector="@android:color/transparent" android:transcriptMode="alwaysScroll" ></ListView> <LinearLayout android:layout_width="fill_parent" android:layout_height="wrap_content" android:orientation="horizontal" > <EditText android:id="@+id/sendText" android:layout_width="0dp" android:layout_height="wrap_content" android:layout_weight="1" /> <Button android:id="@+id/send_btn" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="@string/send" /> </LinearLayout>

</LinearLayout>

leftitem.xml代码

<?xml version="1.0" encoding="utf-8"?><RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" > <TextView android:id="@+id/time" android:layout_width="fill_parent" android:gravity="center_horizontal" android:layout_height="wrap_content" /> <ImageView android:layout_below="@id/time" android:id="@+id/iv" android:layout_width="70dp" android:layout_height="70dp" android:padding="10dp" android:src="@drawable/c" /> <TextView android:layout_below="@id/time" android:layout_toRightOf="@id/iv" android:layout_width="wrap_content" android:layout_height="wrap_content" android:id="@+id/tv" android:gravity="center" android:background="@drawable/d" />

</RelativeLayout>

rightitem.xml代码

<?xml version="1.0" encoding="utf-8"?><RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" > <TextView android:id="@+id/time" android:layout_width="fill_parent" android:gravity="center_horizontal" android:layout_height="wrap_content" /> <ImageView android:layout_below="@id/time" android:layout_alignParentRight="true" android:id="@+id/iv" android:layout_width="70dp" android:layout_height="70dp" android:padding="10dp" android:src="@drawable/b" /> <TextView android:layout_below="@id/time" android:layout_toLeftOf="@id/iv" android:layout_width="wrap_content" android:layout_height="wrap_content" android:id="@+id/tv" android:gravity="center" android:background="@drawable/d" />

</RelativeLayout>

values文件下的strings.xml代码

<?xml version="1.0" encoding="utf-8"?><resources>

<string name="app_name">小兵机器人</string> <string name="action_settings">Settings</string> <string name="hello_world">小兵聊天机器人</string> <string name="send">发送</string> <string-array name="welcome_tips"> <item>主人,奴婢在此等候多时了</item> <item>主人,近来可好</item> <item>欢迎归来,我亲爱的主人</item> <item>主人,我好想你啊</item> <item>主人,你越来越靓啦</item> <item>我是小兵机器人,很高兴陪你聊天</item> <item>我就是聪明,可爱的小兵机器人</item> <item>hello,美女(帅锅)</item> <item>你是我的小呀小苹果</item> <item>开心的话,可以找我聊天,不开心更要找我聊天啦</item> </string-array>

</resources>

AndroidManifest.xml的代码

添加的代码为加黑的粗体。

<?xml version="1.0" encoding="utf-8"?><manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.shenbin.person" android:versionCode="1" android:versionName="1.0" >

<uses-sdk android:minSdkVersion="8" android:targetSdkVersion="18" /> <uses-permission android:name="android.permission.INTERNET"/>

<application android:allowBackup="true" android:icon="@drawable/ic_launcher" android:label="@string/app_name" android:theme="@style/AppTheme" > <activity android:name="com.shenbin.person.MainActivity" android:label="@string/app_name" > <intent-filter> <action android:name="android.intent.action.MAIN" />

<category android:name="android.intent.category.LAUNCHER" /> </intent-filter> </activity>

2024年网页在线客服聊天软件 篇3

成都美洽网络科技有限公司,成立于 2014 年,提供一站式客户互动 SaaS 服务; 目前美洽拥有在线客服、呼叫中心、客服机器人、工单系统和营销机器人 等产品,致力于帮助企业与客户的在线沟通互动场景效率提升,并提供一体化服务营销解决方案; 截至 2021 年第四季度,美洽服务企业用户已超过 35 万家, 覆盖互联网软件、教育培训、医疗、电子商务、金融、生活服务和房地产等行业领域。

全球35万+家企业信赖的多渠道集成在线客服系统

随着互联网时代的推进,建立客户服务中心,提高服务意识和水平将成为众多企业提升竞争力的选择。美洽在线客服系统是美满科技自2014年推出的一款基于SaaS模式的多渠道接入智能在线客服系统,截至2021年第四季度,使用美洽软件的客户已超过35万,遍布医疗、互联网、电商、教育培训等行业。围绕获客转化,美洽在线客服系统可统一集成全网营销渠道,快速触达并留住潜在客户,让付费转化自动成交,实现网页、微信小程序、微信公众号、APP、微博、头条、快手、百度等全渠道接入,沟通无障碍。

智能客服机器人,人机协作带来优质客户体验

美洽智能客服机器人,提供7x24小时全天候热情服务, 通过高标准接待水平,实现5星级客户体验。机器人系统基于深度学习算法,从大量未标注数据中进行学习,从数据中自动总结语言规律,能够处理复杂的语言变化,并对复杂的情感进行建模,回复准确率可度达98%以上,自动实时客服质检。目前,美洽客服机器人已在教育培训、电子商务、互联网企业、医疗美容等行业有深度的应用。

呼叫中心,服务+营销场景双升级

用户在线沟通时,可能会有这样的问题:文字沟通不畅通,客服与用户都不理解彼此想要传达的意思,甚至有时候,双方会对彼此的话产生错误的理解,导致沟通不愉快。这时候,即时的语音沟通就显得很重要了!美洽呼叫中心可直接在美洽工作台开启语音通话,帮助企业更好地服务客户,弥补文字、短信的不足,让交流变得更亲切真实,提高触达客户的效率,获得更好的营销服务效果。

专注于售前【营销获客】的场景解决的营销机器人

美洽营销机器人可以做到用户无感知,就像是人工客服在接待一样,用户体验感极佳。不仅能够7x24小时不间断的为用户提供营销服务,让咨询的访客能够立即获得最佳推荐,营销机器人还可以帮助企业实时获取无限潜在客户,同时,企业可以根据自身业务情况配置个性化的营销方案,真正让企业实现自动化营销,在售前获线场景中100%替代人工客服,给每个潜在客户带来优质且迅速的营销服务!

私有化部署智能客服,满足企业个性化定制需求

美洽私有化部署可根据企业需求定制私有化部署方案,实现业务场景全覆盖,并提供专业团队1对1服务;同时,企业可任意选择服务器或第三方云平台,美洽私有化部署拥有的丰富API接口可做到即时连接,真正实现企业内外部数据完整互通,私有化部署的数据完全独立,保障企业本地私密数据安全可控;此外,基于美洽SaaS 标准化产品,私有化部署可灵活定制功能,满足企业更多个性化智能客服系统的定制需求。

猜你喜欢