ShowAPI,自营为主的数据交易市场
立即注册

外汇牌价汇率查询转换

提供者: 易源官方 部分收费

当前十大银行,包括工商银行、中国银行、农业银行、交通银行、建设银行、招商银行、光大银行、浦发银行、兴业银行、中信银行、的汇率牌价查询,以及一个币种到另一个币种之间一定金额的转换。

浏览量:19215

调用量:69997056

使用人数:9688

点赞:79

申请使用 查看演示
文档 授权签名(重要) 联系信息 价格一览表 接口演示
接入点列表
十大银行实时汇率表
中国银行的实时汇率表
汇率转换
支持的外汇币种列表
数据结构列表
Currency
CodeItem
资源列表
·SDK及代码示例
规则中心
·名词解释
·常见问题

接入点说明

包括工商银行、中国银行、农业银行、交通银行、建设银行、招商银行、光大银行、浦发银行、兴业银行、中信银行十大银行的实时外汇牌价。

请求URL地址

http://route.showapi.com/105-32
注意:接口支持https,更安全,但稍慢一些,你懂的。请根据自己的情况进行选择。

请求参数

HTTP协议,支持GET/POST方法。
非文件上传的POST时,enctype=application/x-www-form-urlencoded。
文件上传的POST时,enctype=multipart/form-data。
1.系统级参数(所有接入点都需要的参数):+点此展开
2.应用级参数(每个接入点有自己的参数):
参数名称 类型 默认值 示例值 必须 描述
bankCode String icbc 银行编码
工商银行:ICBC ,
中国银行:BOC ,
农业银行:ABCHINA ,
交通银行:BANKCOMM ,
建设银行:CCB ,
招商银行:CMBCHINA ,
光大银行:CEBBANK ,
浦发银行:SPDB ,
兴业银行:CIB ,
中信银行:ECITIC

返回参数

以JSON格式返回结果。
1.系统级参数(所有接入点都会返回的参数):+点此展开
2.应用级参数(系统级输出参数showapi_res_body字段中的json数据结构):
名称 类型 示例值 描述
name String icbc 银行编码
time String 01:10:41 时间
day String 2017-03-30 日期
listSize String 23 货币数量(种)
codeList CodeItem[] 汇率列表
- name String 欧元 货币名称
- code String EUR 货币简码
- hui_in String 693.94 现汇买入价
- chao_in String 672.53 现钞买入价
- hui_out String 698.82 现汇卖出价
- chao_out String 698.82 现钞卖出价
- mid_price String 687.44 中间价
ret_code String 0 0为成功,其他失败
  • 请求实例
  • java_sdk
  • 纯java
  • curl
  • php
  • android
  • python

                

                  public static void main(String path[]) throws Exception {
									URL u=new URL("http://route.showapi.com/105-32?showapi_appid=myappid&bankCode=&showapi_sign=mysecret");
									InputStream in=u.openStream();
									ByteArrayOutputStream out=new ByteArrayOutputStream();
									try {
										byte buf[]=new byte[1024];
										int read = 0;
										while ((read = in.read(buf)) > 0) {
											out.write(buf, 0, read);
										}
									}  finally {
										if (in != null) {
											in.close();
										}
									}
									byte b[]=out.toByteArray( );
									System.out.println(new String(b,"utf-8"));
							}
						 
						
						//字段值为中文、空格、特殊符号的地方需要做urlencode,编码为utf-8。用js的方式就是:
						//encodeURIComponent('中文')
						//比如"中文"转换后就是%25E4%25B8%25AD%25E6%2596%2587
            
						
						 //md5签名方式--非简单签名
               			<?php
							header("Content-Type:text/html;charset=UTF-8");
							date_default_timezone_set("PRC");
							$showapi_appid = 'xxxxxx';  //替换此值,在官网的"我的应用"中找到相关值
							$showapi_secret = 'xxxxxxxxx';  //替换此值,在官网的"我的应用"中找到相关值 
							$paramArr = array(
							     'showapi_appid'=> $showapi_appid,
								 'bankCode'=> ""
							     //添加其他参数
							);
							
							//创建参数(包括签名的处理)
							function createParam ($paramArr,$showapi_secret) {
							     $paraStr = "";
							     $signStr = "";
							     ksort($paramArr);
							     foreach ($paramArr as $key => $val) {
							         if ($key != '' && $val != '') {
							             $signStr .= $key.$val;
							             $paraStr .= $key.'='.urlencode($val).'&';
							         }
							     }
							     $signStr .= $showapi_secret;//排好序的参数加上secret,进行md5
							     $sign = strtolower(md5($signStr));
							     $paraStr .= 'showapi_sign='.$sign;//将md5后的值作为参数,便于服务器的效验
							     echo "排好序的参数:".$signStr."
\r\n"; return $paraStr; } $param = createParam($paramArr,$showapi_secret); $url = 'http://route.showapi.com/105-32?'.$param; echo "请求的url:".$url."
\r\n"; $result = file_get_contents($url); echo "返回的json数据:
\r\n"; print $result.'
\r\n'; $result = json_decode($result); echo "
\r\n取出showapi_res_code的值:
\r\n"; print_r($result->showapi_res_code); echo "
\r\n"; ?>
						//以下代码为纯java实现,并未依赖第三方框架,具体传入参数请参看接口描述详情页.
						protected Handler mHandler =  new Handler();
						protected void onCreate(Bundle savedInstanceState) {
								super.onCreate(savedInstanceState);
								setContentView(R.layout.activity_main);
								final TextView txt = (TextView) this.findViewById(R.id.textView1);
								Button myBtn = (Button) this.findViewById(R.id.button1);
								myBtn.setOnClickListener(new OnClickListener() {
									public void onClick(View v) {
										new Thread(){
											//在新线程中发送网络请求
											public void run() {
												String appid="xxx";//要替换成自己的
												String secret="xxxxxxx";//要替换成自己的
												final String res=new ShowApiRequest( "http://route.showapi.com/105-32", appid, secret)
                    .addTextPara("bankCode", "")
            .post();
												
												System.out.println(res);
												//把返回内容通过handler对象更新到界面
												mHandler.post(new Thread(){
													public void run() {
														txt.setText(res+"  "+new Date());
													}
												});
											}
										}.start();
										
										
									}
								});
						}

						
#python3.5
from urllib import    request, parse
import json

print('send data....')
showapi_appid="xxxxxxxxxx"  #替换此值
showapi_sign="xxxxxxxxxx"   #替换此值
url="http://route.showapi.com/105-32"
send_data = parse.urlencode([
    ('showapi_appid', showapi_appid)
    ,('showapi_sign', showapi_sign)
                    ,('bankCode', "")
    
  ])

req = request.Request(url)
try:
       response = request.urlopen(req, data=send_data.encode('utf-8'), timeout = 10) # 10秒超时反馈
except Exception as e:
    print(e)
result = response.read().decode('utf-8')
result_json = json.loads(result)
print ('result_json data is:', result_json)

						

返回实例

{
  "showapi_res_code": 0,
  "showapi_res_error": "",
  "showapi_res_body": {
    "time": "01:10:41",
    "ret_code": 0,
    "name": "ICBC",
    "codeList": [
      {
        "hui_in": "6.1854",
        "chao_out": "6.2295",
        "chao_in": "6.0266",
        "hui_out": "6.2295",
        "name": "日元",
        "mid_price": "--",
        "code": "JPY"
      } 
    ],
    "day": "2017-03-30",
    "listSize": 23
  }
}




请求地址 请求参数 返回参数 请求示例 返回示例
接入点列表
十大银行实时汇率表
中国银行的实时汇率表
汇率转换
支持的外汇币种列表
  • 即充即用流量包(十大银行实时汇率表)

一次性礼包

0时间:1年

  • 1000次调用
  • 不限调用频率
  • 手机认证 要求
  •  
领取

初级版

1 时间:1年

  • 20000次调用
  • 不限调用频率
订购套餐

中级版

9 时间:1年

  • 200000次调用
  • 不限调用频率
订购套餐

高级版

499 时间:1年

  • 12000000次调用
  • 不限调用频率
订购套餐