精华内容
下载资源
问答
  • redis 接入步骤

    2020-05-22 16:20:03
    在我们日常的开发中,无不都是使用数据库来进行数据的存储,由于一般的系统任务中通常不会存在高并发的情况,所以这样看起来并没有什么问题,可是一旦涉及大数据量的需求,比如一些商品抢购的情景,或者是主页访问量...

    redis

    在我们日常的开发中,无不都是使用数据库来进行数据的存储,由于一般的系统任务中通常不会存在高并发的情况,所以这样看起来并没有什么问题,可是一旦涉及大数据量的需求,比如一些商品抢购的情景,或者是主页访问量瞬间较大的时候,单一使用数据库来保存数据的系统会因为面向磁盘,磁盘读/写速度比较慢的问题而存在严重的性能弊端,一瞬间成千上万的请求到来,需要系统在极短的时间内完成成千上万次的读/写操作,这个时候往往不是数据库能够承受的,极其容易造成数据库系统瘫痪,最终导致服务宕机的严重生产问题。

    为了克服上述的问题,项目通常会引入NoSQL技术,这是一种基于内存的数据库,并且提供一定的持久化功能。

    redis技术就是NoSQL技术中的一种,但是引入redis又有可能出现缓存穿透,缓存击穿,缓存雪崩等问题。本文就对这三种问题进行较深入剖析。

    击穿,穿透  雪崩以及解决方案 参考文档 https://blog.csdn.net/qq_27409289/article/details/85885121  |||   https://www.cnblogs.com/xichji/p/11286443.html

     

     

    SET key value

    含义:

              将字符串值 value 关联到 key 。

              如果 key 已经持有其他值, SET 就覆写旧值,无视类型。

     

    SETEX key seconds value

    含义:

               将值 value 关联到 key ,并将 key 的生存时间设为 seconds (以秒为单位)。

               如果 key 已经存在, SETEX 命令将覆写旧值。

    返回值:

               设置成功时返回 OK 。

               当 seconds 参数不合法时,返回一个错误。

     

    SETNX key value

    含义:

               将 key 的值设为 value ,当且仅当 key 不存在。

               若给定的 key 已经存在,则 SETNX 不做任何动作。

               SETNX 是『SET if Not eXists』(如果不存在,则 SET)的简写。

    返回值:

               设置成功,返回 1 。

               设置失败,返回 0 。

     

    GETSET key value

    含义:

              将给定 key 的值设为 value ,并返回 key 的旧值(old value)。

              当 key 存在但不是字符串类型时,返回一个错误。

    返回值:

               返回给定 key 的旧值。

               当 key 没有旧值时,也即是, key 不存在时,返回 nil 。


    引用(https://blog.csdn.net/iteye_7682/java/article/details/82680515)

     

    如果需要存储对象  可以引用Redis 哈希(hash)hmset方法 具体参考:https://www.runoob.com/redis/redis-hashes.html

     

    展开全文
  • 老生常谈,推送接入已经不是什么难事,跟着文档走几小时就能搞定。不过我这里还是要记录一下,因为我在接入的时候还是有坑。希望这篇文章可以帮到你。 VVIO客户端 厂商推送,无非就是收到推送拉起通知。所以在最新版...

    老生常谈,推送接入已经不是什么难事,跟着文档走几小时就能搞定。不过我这里还是要记录一下,因为我在接入的时候还是有坑。希望这篇文章可以帮到你。

    VVIO客户端

    厂商推送,无非就是收到推送拉起通知。所以在最新版中,官方说明已经移除了透传部分,无需再用透传接收自行处理了,向华为小米看齐了。
    数据接收需要在被拉起的Activity中使用getIntent接收 就等于你普通页面间传值。
    依赖包也又jar升级为aar少了部分配置。
    详细适配步骤请移步VIVO推送官方文档

    这里只讲一下参数接收

    在你想要点击通知后拉起的Activity配置

    <activity android:name=".CustomActivity"   
        android:exported="true">
        <intent-filter>
            <action android:name="android.intent.action.VIEW" />
            <category android:name="android.intent.category.DEFAULT" />
            <category android:name="android.intent.category.BROWSABLE" />
            <data
                android:host="com.vivo.push.notifysdk"
                android:path="/detail"
                android:scheme="vpushscheme" />
            </intent-filter>
    </activity>
    

    参数解析:
    关于意图过滤器详解请移步博客园相关文章
    这里只说服务端发送的参数Uri和客户端接收之间的对应关系
    比如 <data /> 里
    android:hostandroid:pathandroid:scheme
    分别对应的值为:
    com.vivo.push.notifysdk/detailvpushscheme

    那么服务端的对应 Uri 也就是想客户端发送的数据 就应该这么写

    intent://com.vivo.push.notifysdk/detail?#Intent;scheme=vpushscheme;end
    

    OK!这样就可以拉起你的 CustomActivity 页面了。
    那如果要传递参数 该怎么搞呢?
    同理

    intent://com.vivo.push.notifysdk/detail?customkey=param;#Intent;scheme=vpushscheme;end
    

    其中customkey为你传参的键 param为键对应的值

    对应Activity中的接收就是

    getIntent().getStringExtra("customkey");
    

    这样就可以在通知拉起 CustomActivity 页面时通过Intent接收到后台传递过来的值了。拿到值就可以做你自己想做的操作了。

    关于混淆

    -dontwarn com.vivo.push.** 
    
    -keep class com.vivo.push.**{*; } 
    
    -keep class com.vivo.vms.**{*; }
    
    -keep class xxx.xxx.xxx.PushMessageReceiverImpl{*;}//这个是你需要透传的那个类,如果没实现透传接口 可以忽略。
    

    VIVO服务端

    服务端开发很少有人讲,因为推送服务器和app这快都是我一个搞的,所以这里顺带讲一下。
    服务端一般分为SDK开发和API开发。说白了:就是服务器去请求第三方推送的接口来显示推送的点目的。
    API开发和SDK开发怎么选仁者见仁智者见智。
    我这里选择SDK开发,因为快。等于第三方已经帮你封装好了网络请求部分。
    VIVO推送服务端文档

    服务端VIVO的核心是Sender类 也就是一个网络封装类,你直接调用即可。

    Sender sender = new Sender("appSecret");//注册登录开发平台网站获取到的appSecret
    

    然后就是一个Token 我们自己推送服务器和第三方推送之间的一个登陆凭证。
    按照官方的说法是本地做处理,最好4-6小时重新更新一次Token。

    Result tokenResult = sender.getToken(appId, appKey);
    String token = tokenResult.getAuthToken();
    

    这里获取到的Token 需要你保存到本地。然后加个计时器或者时间戳什么的。反正触发条件是每隔4-6小时重新调用一次getToken即可。以避免Token失效。

    OK!拿到Token后 就可以发送推送指令了。发送推送指令 就需要构造消息体:

    Message.Builder vPushBuilder = new Message.Builder()
            .title("XXX")//标题
            .content("XXXXXX")//内容
            .notifyType(4)//响铃+震动
            .timeToLive(300)//存活时间 必填 单位/秒 这里根据你们APP的应用场景来定,我这里由于时效性,时间太久这条推送就没意义了,所以设置的5分钟。
            .skipType(3)//打开App指定页
            .classification(1)//消息类型 0运营消息 1系统消息(无限制)
            .pushMode(0)//消息类型 0正式推送 1测试推送(测试推送上限20个设备)
            .requestId(System.currentTimeMillis())//请求唯一id 标记当前 我这里用时间戳代替,请根据自己需求自行定制
            .pushMode(0);//0正式推送 1测试推送(基本没用)
            .skipContent("Intent URI")//跳转内容
            .regId("User Token")//发送推送
            .build();
    

    这里参数只讲一下
    skipContent(“Intent URI”)regId(“User Token”)

    skipConent 为 传递给App的参数 也就是 这段代码

    intent://com.vivo.push.notifysdk/detail?#Intent;scheme=vpushscheme;end
    

    regId 为 app 端调用vivo推送的sdk后获取到的一个唯一设备token。可以理解为指定某一台设备。

    //app端获取 regId
    String regId = PushClient.getInstance(getApplicationContext()).getRegId();
    

    消息构造完成。
    接下来就是发送,这里使用单推,也就是单独推送(指定用户),也有群发和指定别名推送,这里请查阅官方文档根据自身需求操作。

    sender.setAuthToken(IMServer.vPushToken);//设置推送的必要参数authToken(调用鉴权方法获得)
    //发送单推消息
    Result result = sender.sendSingle(builder.regId(userTokensJson).build());
    //回调 其他回调参数请查阅官方文档
    result.getResult()   // 获取平台返回的 0成功,非0失败
    result.getDesc()    // 获取请求的服务器信息
    

    result.getResult() == 0 表示推送成功,如果!=0 推送失败,可以做再次推送的处理。就看自身业务需求了。

    到此 VIVO推送 要说的地方就整理完毕

    接下来时OPPO推送 两个差不多,接了VIVO再集成OPPO就很快了。

    OPPO 客户端

    OPPO推送 范围比较广,接入OPPO推送就等于同时适配
    OPPO Realme 和 一加(新机型) 因为它们的ROM都是Color OS
    详情官方文档

    权限

    <uses-permission android:name="com.coloros.mcs.permission.RECIEVE_MCS_MESSAGE" />
    <uses-permission android:name="com.heytap.mcs.permission.RECIEVE_MCS_MESSAGE" />
    

    参数接收

    和VIVO同理 这里不再赘述。

    关于混淆

    -keep public class * extends android.app.Service //app一般都会默认混淆
    -keep class com.heytap.msp.** { *;}
    

    推送通道适配

    Andoird 8.0 引入了 通知通道的概念,具体请自行搜索 [ Android8.0通知适配 ]
    这里只说一下通道id 因为服务器端需要用到

    NotificationChannel channel = new NotificationChannel(channelId, channelName, NotificationManager.IMPORTANCE_HIGH);
    

    其中 channelId 就是通道id 自定义 必须创建,否则无法接收OPPO推送

    OPPO服务端

    OPPO服务端也是Sender 注意两个包不一样,只是名字相同。

    Sender sender = new Sender("appKey", "masterSecret");
    

    这里Sender 内部进行了封装,内部维护了一个token时效,我问了OPPO的开发人员,他们说不用处理。会自动更新。

    不过消息对象是 Notification 比较符合Android开发的概念

    Notification notification = new Notification();
    notification.setTitle("OPush->" + contentBean.getTitle());
    notification.setContent(contentBean.getContent());
    notification.setOffLineTtl(300);//存活时间 必填 单位/秒 这里 5分钟
    notification.setStyle(1);//默认短文本1 长文本2 大图3
    notification.setClickActionType(4);//点击动作 4为打开应用内页 也就是某个Activity
    notification.setOffLine(false);//不要离线消息,这个推送是实时的。3天不登录就不推送了。
    notification.setClickActionActivity("包名.CustomActivity");//设置内页地址
    notification.setActionParameters("{\"key\":\"" + param+ "\"}");//传递的参数 json 格式 举例:{"key","param"}
    

    不过 OPPO推送的 参数格式 不是Intent URI了,改为了JSON字符串。这里写的时候注意转码或者用 JsonObject 自行转换。

    {"key":"param","key0":"param0"}
    

    上面说了,无需操心token问题 那么数据构造完成,就需要发送了。

    这里还是举例单推。

    发送一条单推:

    Target target = Target.build(userToken); //创建发送对象
    Result result = IMServer.oPushSender.unicastNotification(messageObj, target);
    
    result.getMessageId()   // 获取平台返回的messageId
    result.getStatusCode()    // 获取http请求状态码
    result.getReturnCode().getCode()    // 获取平台返回码
    

    其中 userToken 为oppo推送的app端sdk生成。

    HeytapPushManager.register(getApplicationContext(), OPPO_APP_KEY, OPPO_APP_SECRET, new ICallBackResultService() {
        @Override
        public void onRegister(int code, String s) {
            if (code == 0) {
                Log.i("注册成功", "registerId:" + s);
            } else {
                Log.i("itl-注册失败", "code=" + code + ",msg=" + s);
            }
        }
        
        public void onUnRegister(int code){...}
        public void onGetPushStatus(final int code, int status) {...}
        public void onGetNotificationStatus(final int code, final int status){...}
        
    });
    

    其中 onRegister为 回调类 中 向oppo推送注册成功后获取的唯一设备id

    至此,OV推送基本大体流程基本完成。之前的小米华为也是类似。

    展开全文
  • 本篇博客记录自己在使用onenet平台中的http协议接入自己的设备并进行上传数据等操作。 对于使用物联网平台,阅读平台的开发者文档很重要,可以先阅读找到自己需要的部分,链接: 开发文档。 建立账户等操作不做赘述,...

    本篇博客记录自己在使用onenet平台中的http协议接入自己的设备并进行上传数据等操作。
    对于使用物联网平台,阅读平台的开发者文档很重要,可以先阅读找到自己需要的部分,链接: 开发文档
    建立账户等操作不做赘述,链接: 创建用户。由于作图比较麻烦,直接采用文字+图片叙述步骤,多图警告。
    先进入开发者界面中。

    创建产品,设备

    按着图的步骤一步步操作即可,首先点击多协议接入,进入控制台界面。
    在这里插入图片描述
    进入后添加你需要的产品类型
    在这里插入图片描述
    添加完产品后就可以添加设备了
    在这里插入图片描述
    在这里插入图片描述
    设备名称编号什么的根据自己实际情况来,作用只是区分你添加的设备。

    建立数据流模板

    进入此界面后点击数据流
    在这里插入图片描述
    点击数据流模板管理后,再点击创建数据流模板
    在这里插入图片描述
    单位名称以及符号可以不设置,但数据流名称最好与产品名称保持一致。

    在这里插入图片描述

    进入刚刚的页面,点击详情,并添加你的APIkey,至于添加什么也是随意的,系统会给你随机生成一个。在这里插入图片描述

    在这里插入图片描述

    模拟连接平台,测试平台

    生成后进入API调试进行模拟测试
    在这里插入图片描述

    到这里我们已经的得到了下面几个参数

    APIKey:KDH=4Ue3=7dfaTeEO6ncPLR4v6g=
    设备ID:706294069
    数据流模板ID:test
    设备API基地址:http://api.heclouds.com/devices/706294069
    

    我们模拟通过HTTP协议提交数据,完整的路由为:

    http://api.heclouds.com/devices/706294069/datapoints
    

    接下来只要把这些数据填入上面的界面中。
    中间使用的请求参数为

    {"datastreams": [{"id": "test","datapoints": [{"value": 3}]}]}
    

    填入后执行请求,右侧返回succ表明请求成功
    在这里插入图片描述
    至此,我们返回数据的操作就算完成了。
    在这里插入图片描述
    如果需要在本地环境下用python语言连接物联网平台,请点击这里(后续会更新)。

    学习笔记参考此篇文档链接: 中移物联OneNET平台HTTP协议接入
    .

    展开全文
  • 目录介绍简介关于本次CodeLab你将建立什么你会学到什么你需要什么申请Camera相关权限集成HwCameraKit开放能力步骤1 模式创建:获取CameraKit实例,创建人像模式步骤2 配置模式:配置模式的状态回调,数据回调及处理...

    介绍

    在这里插入图片描述

    简介

      HwCameraKit为开发者提供了一套兼容EMUI的相机能力开放接口,开发者可以通过HwCameraKit使自己的应用快速接入华为相机的私有能力,扩展应用的拍摄功能,为用户提供更好拍摄体验。

      人像模式为HwCameraKit开放的多种相机模式其中之一,它将允许您:

    • 获取华为相机的人像拍摄能力,包括背景虚化、环境光、瘦脸,皮肤光滑、调色等能力;
    • 提供相机模式高级编程接口,简化相机应用开发,并借助IDE工具快速接入上述能力。

    关于本次CodeLab

    你将建立什么

      在本次CodeLab中,您将使用HwCameraKit建立一款Android相机应用程序,使其可以获得华为相机的人像拍摄功能,实现人像的虚化、美肤等效果。
    在这里插入图片描述
    普通拍摄(左) VS 人像模式开启虚化(右)

    你会学到什么

    • 使用HwCameraKit IDE高效集成华为相机开放能力
    • 熟悉HwCameraKit基本开发模式

    你需要什么

    硬件要求

    1. 开发计算机(台式机或笔记本电脑)
    2. 操作系统为EMUI10.0及以上版本的华为手机

    软件要求

    1. JAVA JDK安装包
    2. Android SDK包
    3. HwCameraKit IDE工具:DevEco

    申请Camera相关权限

    Duration: 0:05
      1. 在工程的Manifest文件中添加相关权限:

    <uses-permission   android:name="android.permission.CAMERA"/>
     
    <uses-permission android:name="android.permission.RECORD_AUDIO"/>
    
    <uses-permission   android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
    

      2. 动态申请相关权限:

    private static final String [] PERMISSIONS_ARRAY = new String[]   {
        Manifest.permission.WRITE_EXTERNAL_STORAGE,
        Manifest.permission.CAMERA, Manifest.permission.RECORD_AUDIO, Manifest.permission.ACCESS_FINE_LOCATION
    };
    
    private static List<String> permissionsList = new ArrayList<>(PERMISSIONS_ARRAY.length);
    
    /**
    
     * 动态请求WRITE_EXTERNAL_STORAGE CAMERA RECORD_AUDIO权限
     *
     * @param activity 应用activity
    
     */
    
    public static void requestPermission (final Activity activity) {
        for (String permission : PERMISSIONS_ARRAY) {
        if (ContextCompat.checkSelfPermission(activity, permission) != PackageManager.PERMISSION_GRANTED) {
            permissionsList.add(permission);
        }
    }
        ActivityCompat.requestPermissions(activity, permissionsList.toArray(new String [permissionsList.size()]), REQUEST_CODE_ASK_PERMISSIONS);
    }
    

    集成HwCameraKit开放能力

    Duration: 0:60
      通过IDE提供的功能卡片,可以快速获取示例代码并将其添加到工程中,以人像模式为例,找到人像能力卡片:可通过Tools->EMUI Kits->Kit Assistant->Camera->Portrait Mode 来找到该卡片。

    在这里插入图片描述

    提示:本次Codelabs提供了配套的app开发工程,请使用IDE工具导入,并根据如下步骤,实现提供的配套工程中带有/* TODO */注释的方法,从而快速集成人像模式。

    步骤1 模式创建:获取CameraKit实例,创建人像模式

    private   @Mode.Type int mCurrentModeType;
    
    private CameraKit mCameraKit;
    
    private ModeCharacteristics mModeCharacteristics;
    
    private void createMode() {
        
        mCameraKit = CameraKit.getInstance(getApplicationContext());
        
        if (mCameraKit == null) {
            Log.e(TAG, "This device does not   support CameraKit!");
        }
        
        /** Query camera id list*/
        
        String[] cameraLists = mCameraKit . getCameraIdList ();
        
        if ((cameraLists != null) && (cameraLists.length > 0)) {
            
            Log.i(TAG, "Try to use camera   with id " + cameraLists[0]);
            
            /** Query supported modes of this   device*/
    
            int[] modes = mCameraKit . getSupportedModes (cameraLists[0]);
            
            if (!Arrays.stream(modes).anyMatch((i)   -> i == mCurrentModeType)) {
                Log.w(TAG, "Current mode is   not supported in this device!");
                return;
            }
            mCameraKit.createMode(cameraLists[0], mCurrentModeType, mModeStateCallback, mCameraKitHandler);
        }
        
    }
    

    步骤2 配置模式:配置模式的状态回调,数据回调及处理这些回调的Handler,以及预览、拍照分辨率等参数

      从mModeStateCallback的onCreated回调后,可从入参可获得人像Mode实例

    /** 在onCreated回调中获取mode对象,然后以行为的状态回调和数据回调及对应的线程为入参,初始化ModeConfig.Builder,配置预览的surface和拍照的大小,通过configure命令将配置项设置到mMode中,进行模式的激活*/
    private   void configMode() {
    
        Log.i(TAG, "configMode begin");
    
        /** Query supported preview size*/
    
        List<Size> previewSizes =   mModeCharacteristics.getSupportedPreviewSizes(SurfaceTexture.class);
    
        /** Query supported capture size*/
    
        List<Size> captureSizes =   mModeCharacteristics.getSupportedCaptureSizes(ImageFormat.JPEG);
    
        Log.d(TAG, "configMode: captureSizes   = " + captureSizes.size() + ";previewSizes=" +   previewSizes.size());
    
        /** Use the first one or default   4000x3000*/
        mCaptureSize =   captureSizes.stream().findFirst().orElse(new Size(4000, 3000));
        /** Use the same ratio with preview*/
    
        mPreviewSize =   previewSizes.stream().filter((size) -> Math.abs((1.0f * size.getHeight() /   size.getWidth()) - (1.0f * mCaptureSize.getHeight() /   mCaptureSize.getWidth())) < 0.01).findFirst().get();
        Log.i(TAG, "configMode: mCaptureSize   = " + mCaptureSize + ";mPreviewSize=" + mPreviewSize);
    
        /** Update view*/
    
        runOnUiThread(() ->   mTextureView.setAspectRatio(mPreviewSize.getHeight(), mPreviewSize.getWidth()));
    
        SurfaceTexture texture =   mTextureView.getSurfaceTexture();
    
        if (texture == null) {
            Log.e(TAG, "configMode:   texture=null!");
            return;
        }
    
        /** Set buffer size of view*/
    
        texture.setDefaultBufferSize(mPreviewSize.getWidth(),   mPreviewSize.getHeight());
    
        /** Get surface of texture*/
    
        Surface surface = new Surface(texture);
    
        /** Add preview and capture parameters to   config builder*/
    
        modeConfigBuilder.addPreviewSurface(surface).addCaptureImage(mCaptureSize,   ImageFormat.JPEG);
    
        /** Set callback for config builder*/
    
        modeConfigBuilder.setDataCallback(actionDataCallback,   mCameraKitHandler);
    
        modeConfigBuilder.setStateCallback(actionStateCallback,   mCameraKitHandler);
    
        /** Configure mode*/
    
        mMode.configure();
        Log.i(TAG, "configMode end");
    }
    

      使用构造器ModeConfig.Builder配置模式的状态回调及数据回调及执行回调所在的Handler。从状态回调中,开发者可以获取如启动预览后状态变化、拍照结束状态、手动对焦结束、人脸检测结果返回等信息;从数据回调中,开发者可获取模式动作执行过程中产生数据结果(如拍照图像数据等)。还可通过ModeConfig.Builder配置预览Surface及拍照分辨率。

    步骤3 模式操作

    3.1 开启预览

    /* 在接收到到onConfigured回调后,说明mode配置成功,模式进入开启状态,此时调用startPreview命令开启预览。*/
    
    private   void startPreview() {
        mMode.startPreview();
    }
    

    3.2 参数设置

    /* 用户可以通过ModeCharacteristics#getSupportedParameters查询当前模式下支持的参数(以人像模式为例:支持背景虚化,美肤等),通过ModeCharacteristics#getParameterRange查询参数支持的取值范围,通过Mode#setParameter设置对应效果。*/
    
    /* 设置人像虚化 */ 
    mMode.setParameter(RequestKey.HW_PORTRAIT_SPOTS_BOKEH,   validValue);
    
    /* 设置美肤:皮肤光滑 */
    int[]   smoothLevels =   modeCharacteristics.getSupportedBeauty(Metadata.BeautyType.HW_BEAUTY_SKIN_SMOOTH);
    if   (smoothLevels != null && smoothLevels.length != 0) {
    mMode.setBeauty(Metadata.BeautyType.HW_BEAUTY_SKIN_SMOOTH,smoothLevels[smoothLevels.length - 1]);
    }
    /* 用户可以通过设计按钮等方式,调用takePicture进行拍照,异步通过onImageAvailable回调,返回照片Image数据。*/
    mMode.takePicture();
    

    步骤4 操作Callback

    /* 以数据回调为例,在拍照后从回调里获取图片 */
    private   final ActionDataCallback actionDataCallback = new ActionDataCallback() {
        @Override
        public void onImageAvailable(Mode mode,   int id, Image image) {
            super.onImageAvailable(mode, id,   image);
            Log.d(TAG,   "onImageAvailable");
            new ImageSaver(image, mFile,   CameraKitActivity.this).run();
        }
    };
    

    提示:除了从ActionDataCallback获取拍照图片等数据以外,从ActionStateCallback中还可获取模式动作执行过程中,执行状态结果的回调处理,如启动预览后状态变化、拍照结束状态、手动对焦结束、人脸检测结果返回等。

    步骤5 模式释放

    /* 应用切后台,需要将模式释放 */
    @Override
    protected   void onPause() {
        if (mBackgroundHandler != null) {
            mBackgroundHandler.post(new   Runnable() {
                @Override
                public void run() {
                    if (mMode != null) {
                        mMode.release();
                        mMode = null;
                    }
                }
            });
        }
        super.onPause();
    }
    

    恭喜你

    • HwCameraKit IDE插件的安装和使用
    • 利用HwCameraKit将华为相机开放能力接入app

    更多HwCameraKit相关信息请关注我们的官网:
    https://developer.huawei.com/consumer/cn/CameraKit


    往期链接:Android | 教你如何快速集成机器学习能力
    内容来源:https://developer.huawei.com/consumer/cn/forum/topicview?tid=0201234569803940158&fid=3467
    原作者:艾罗门特

    展开全文
  • 昨天已经对接支付宝可以支付了,但是还得处理好回调...先想办法看看支付宝给我返回来什么样的数据,看我的配置文件config.php 'alipay'=>array( 'appid'=>'201601*********', 'returnType'=>'json','...
  • Tracing 数据模型 Tracing 的架构设计 从 Tracing 到 OpenTracing OpenTracing 做了什么事情 Tracing 的由来 随着微服务技术的发展与实践,越来越多应用从单体应用架构转向了微服务架构。微服务技术使得应用能够很...
  • 前端开发_大屏技术——李郑雄 2018-04-261、开发流程概述:主要流程包含以下步骤:需求调研,场景布局,UI设计,DEMO确认,场景切图,场景开发,测试部署,上线演示,迭代调整,数据同步及接入,正式上线。...
  • 数据仓库层级划分

    2020-10-14 21:57:57
    • 屏蔽原始数据的异常:不必改一次业务就需要重新接入数据。 • 把复杂问题简单化:将一个复杂的任务分解成多个步骤来完成,每一层只处理单一的步骤,比较简单和容易理解。而且便于维护数据的准确性,当数据出现.....
  • 移动APN设置移动设置APN:安卓手机需要把设备的接入点改成CMIOT 具体步骤如下: A、找到设置移动网络,接入点名称选添加或者新建。 B、APN设置为CMIOT 名称设置为CMIOT 保存并重启即可。【全部设置大写字母】联通APN...
  • 并且,即使在未关注的情况下,只要用户授权,也能获取其信息),AuthAction.class.php默认为snsapi_base,而且session中只记录了snsapi_base中的基础数据,如需要snsapi_userinfo请自行修改。 具体的实现方法见代码...
  • 数据仓库基础

    2012-03-29 13:25:26
    第一章对数据仓库的迫切需求...................................................................................................23 本章目标:.................................................................
  • 数据结构 1800题》

    热门讨论 2012-12-27 16:52:03
    二者有何相同和不同之处,抽象数据类型的主要特点是什么? 使用抽象数据类型的主要好处是什么?【北京邮电大学 1994 一(8分)】 4. 回答问题(每题 2分)【山东工业大学 1997 一 (8分)】 (1)在数据结构课程中...
  • 数据查询语言 (Data Query Language, DQL) 是SQL语言中,负责进行数据查询而不会对数据本身进行修改的语句,这是最基本的SQL语句。例如:SELECT(查询)  数据控制语言Data Controlling Language(DCL),用来...
  • 什么是VLAN

    2013-10-23 09:59:12
    那么可以简单的将销售部全部接入一个交换机,然后接入路由器的一个端口,把企划部全部接入一个交换机,然后接入一个路由器端口。这种情况是LAN.然而正如上面所说,如果路由器就一个用于终端的接口,那么这两个交换机...
  • 数据结构(C++)有关练习题

    热门讨论 2008-01-02 11:27:18
    内容及步骤: 1、 设计一个图的类,采用临表法进行存储,该图每个结点的数据类型类模板的模板参数进行定义(注:需先设计一个结点类Node); 2、 为该类分别设计一个实现深度优先搜索和广度优先搜索的成员...
  • 04-回顾MySQL主从复制配置步骤及注意事项.avi 05-回顾MySQL主从复制原理要点.avi 06-企业场景MySQL主从复制最牛部署方案.avi 07-一键获取全备及binlog位置多种方案讲解.avi 08-不停主库一键批量配置MySQL主从复制...
  • + 决定要向连接中写入什么数据, 把这些数据缓存 + 等待连接可写 + 写入尽可能多的数据 + 记住写入了多少数据,如果还有数据没写完。等待连接再次变为可写状态。  这样的I/O缓冲方式很常见,因而libevent...
  • 1.1 为什么要用编译器 2 1.2 与编译器相关的程序 3 1.3 翻译步骤 5 1.4 编译器中的主要数据结构 8 1.5 编译器结构中的其他问题 10 1.6 自举与移植 12 1.7 TINY样本语言与编译器 14 1.7.1 TINY语言 15 1.7.2 TINY...
  • QtScrcpy使用指南

    2021-04-22 10:34:12
    QtScrcpy是一款功能强大的Android实时投屏软件,让大家的电脑通过USB数据线或者无线网接到安卓手机,不需要什么root权限就可以让安卓手机在Mac电脑上进行实时投屏。想要知道如何使用QtScrcpy手机投屏功能的朋友,那...
  • 大概是第三方接入阿里云,然后我在接入第三方支付! !本人很菜,不接受反驳! biubiubiu~ (づ ̄3 ̄)づ╭❤~ 先写一下开发步骤吧! 上级领导给我一份第三方支付的文档! 我们先解压文档,并且打开...
  • ②填出在上述控方式的情况下,相应存储中哪一个单元应填入什么数? H IS1 Ik1 aLL alL IESLL N7 SLL SLL 20.说明模拟交换、数字交换、布控交换和程控攵的基本概念 答 谟拟交換:就是对拟信号进行交换的文换方式,如步...
  • 设备接入云平台,可以通过智能手机实时了解当前状态,通过智能算法评估出安全系数,来做出针对性的防护措施。并且还可以手动作出修正处理。 智能厨房安全监控三部分: 家庭卫士通过多传感器对厨房温湿度、燃气、明火...
  • 问题4-1:以太网使用载波监听多点接入碰撞检测协议CSMA/CD。频分复用FDM才使用载波。以太网有没有使用频分复用? 问题4-2:在以太网中,不同的传输媒体会产生不同的传播时延吗? 问题4-3:在以太网中发生了碰撞是否...
  • 简单的完成端口

    2018-02-05 11:48:41
    我们预先准备的那几个Worker线程就不能闲着了, 我们在前面建立的几个Worker就要忙活起来了,都需要分别调用GetQueuedCompletionStatus() 函数在扫描完成端口的队列里是否有网络通信的请求存在(例如读取数据,...

空空如也

空空如也

1 2 3 4 5 ... 11
收藏数 204
精华内容 81
关键字:

数据接入需要什么步骤