项目设计-异常设计

1.异常的简介

      在编程语言中,异常定义了程序中遇到的非致命的错误,比如,程序要打开一个不存的文件、网络连接中断、除零操作、操作数越界、装载一个不存在的类等情况。异常程序是指程序执行一些非法指令,如特权指令,来达到破坏坏系统或程序功能和安全的目的。

简单的来说,是系统非正常运行时产生的,一种结果。

2.设计原则

用户必须得到: 1.正确的执行。2.错误的反馈。

当程序正确执行时,程序就会返回用户想要的结果。

当程序执行错误的时候,必须告诉用户 ①出错在位置,②为什么出错,③下一步如何去操作。

例如 :

你去办个业务,填了一个单子,你填好了,你提交时工作人员时。工作人员告诉你表单填错了。那到底错在哪里,该如何修改。你懵了。

3.异常类能解决哪些问题:

1. 归类处理不同的异常,

2. 用户在给你反馈时,能提供足够的信息,追追踪问题,并且调试。

3. 是让主流程代码保持整洁。

4. 当用户输入错误时,直接抛出异常,结束该流程,可减少运算。

3.异常处理类

代码示例

//某个代码区块抛出异常

throw new RuntimeException("用户输入错误");


//某个代码区块抛出异常
throw new RuntimeException("用户违规操作");


//某个代码区块抛出异常
throw new RuntimeException("用户输入名称过长");


try {
   //代码区块
} catch (JSONException e) {
   //错误一
   e.getMessage() //获取错误详情
} catch (RuntimeException e) {
   //错误二
    e.getMessage()//获取错误信息为:1. 用户输入错误 2.用户违规操作 3.用户输入名称过长
}

我们以上述代码为例,


1.当JSONException  分组出错时,我们很快就知道,JSON 类出了问题,并且 e.getMessage()可以获取详情。

2.当 RuntimeException  分组出错时,我们很快就会知道,都是用户错误操作造成的错误。

我们调用某个 API 时,这时候返回的错误更加精确。

4.简单的代码示例(flutter 项目):

https://github.com/waliu/flutter_plugin_wechat_chenyu
package com.jxm.flutter_plugin_wechat_chenyu;

import android.app.Activity;
import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.content.IntentFilter;
import android.util.Log;

import androidx.annotation.NonNull;
import androidx.annotation.Nullable;

import com.tencent.mm.opensdk.openapi.IWXAPI;
import com.tencent.mm.opensdk.openapi.WXAPIFactory;

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

import java.util.Objects;

import io.flutter.embedding.engine.plugins.FlutterPlugin;
import io.flutter.embedding.engine.plugins.activity.ActivityAware;
import io.flutter.embedding.engine.plugins.activity.ActivityPluginBinding;
import io.flutter.plugin.common.MethodCall;
import io.flutter.plugin.common.MethodChannel;
import io.flutter.plugin.common.MethodChannel.MethodCallHandler;
import io.flutter.plugin.common.MethodChannel.Result;

import static com.jxm.flutter_plugin_wechat_chenyu.Constants.WeChat_APP_ID;

/**
 * FlutterPluginWechatChenyuPlugin
 */
public class FlutterPluginWechatChenyuPlugin implements FlutterPlugin, ActivityAware, MethodCallHandler {
    /// The MethodChannel that will the communication between Flutter and native Android
    ///
    /// This local reference serves to register the plugin with the Flutter Engine and unregister it
    /// when the Flutter Engine is detached from the Activity
    private MethodChannel channel;
    //Flutter Activity
    private Activity activity;
    //标识符
    private static final String TAG = "Plugin.WeChat";
    // IWXAPI 是第三方app和微信通信的openApi接口
    public static IWXAPI api;
    // 分享对象
    private Share share;
    //支付
    private Pay pay;
    //小程序类
    private MiniProgram miniProgram;
    // 认证类
    public AuthRequest authRequest;

    @Override
    public void onAttachedToEngine(@NonNull FlutterPluginBinding flutterPluginBinding) {
        channel = new MethodChannel(flutterPluginBinding.getBinaryMessenger(), "flutter_plugin_wechat_chenyu");
        channel.setMethodCallHandler(this);
    }

    @Override
    public void onMethodCall(@NonNull MethodCall call, @NonNull Result result) {
        try {
            isWXAppInstalled();
            if (call.method.equals("getPlatformVersion")) {
                result.success("Android " + android.os.Build.VERSION.RELEASE);
                return;
            }
            if (call.method.equals("share")) {
                this.threadShare(call, result);
                return;
            }
            if (call.method.equals("auth")) {
                this.auth(call.arguments);
                result.success(Constants.success);
                return;
            }

            if (call.method.equals("sendPaymentRequest")) {
                this.sendPaymentRequest(call.arguments);
                result.success(Constants.success);
                return;
            }

            if (call.method.equals("openMiniProgram")) {
                this.openMiniProgram(call.arguments);
                result.success(Constants.success);
                return;
            }
            result.notImplemented();
        } catch (JSONException e) {
            result.error("500", Constants.Error501, e.getMessage());
        } catch (RuntimeException e) {
            result.error("500", e.getMessage(), e.getMessage());
        }
    }

    @Override
    public void onDetachedFromEngine(@NonNull FlutterPluginBinding binding) {
        channel.setMethodCallHandler(null);
    }


    private void isWXAppInstalled()  {
        if (!api.isWXAppInstalled()) {
            throw new RuntimeException(Constants.Error500);
        }
    }
    private void threadShare(@NonNull MethodCall call, @NonNull Result result) {
        new Thread() {
            public void run() {
                try {
                    FlutterPluginWechatChenyuPlugin.this.share(call.arguments);
                    result.success(Constants.success);
                } catch (JSONException e) {
                    result.error("500", Constants.Error501, e.getMessage());
                } catch (RuntimeException e) {
                    result.error("500", e.getMessage(), e.getMessage());
                }
            }
        }.start();
    }

    private void share(Object arguments) throws JSONException, RuntimeException {
        JSONObject options = new JSONObject(arguments.toString());
        //获取参数
        JSONObject message = options.getJSONObject("message");
        JSONObject mediaObject = message.getJSONObject("mediaObject");

        switch (options.getString("type")) {
            case "text":
                share.shareText(options, message, mediaObject);
                break;
            case "img":
                share.shareImg(options, message, mediaObject);
                break;
            case "music":
                share.shareMusic(options, message, mediaObject);
                break;
            case "video":
                share.shareVideo(options, message, mediaObject);
                break;
            case "webpage":
                share.shareWebpage(options, message, mediaObject);
                break;
            default:
                throw new RuntimeException(Constants.Error501);
        }
    }

    private void auth(Object arguments) throws JSONException {
        JSONObject options = new JSONObject(arguments.toString());
        //获取参数
        // send oauth request
        authRequest.auth(options);
    }

    private void sendPaymentRequest(Object arguments) throws JSONException {
        JSONObject options = new JSONObject(arguments.toString());
        //支付
        pay.sendPaymentRequest(options, WeChat_APP_ID);
    }

    private void openMiniProgram(Object arguments) throws JSONException, RuntimeException {
        JSONObject options = new JSONObject(arguments.toString());
        miniProgram.openMiniProgram(options);
    }

    @Override
    public void onAttachedToActivity(@NonNull ActivityPluginBinding binding) {
        activity = binding.getActivity();

        api = WXAPIFactory.createWXAPI(activity, WeChat_APP_ID, false);
        // 将应用的appId注册到微信
        api.registerApp(WeChat_APP_ID);
        //创建分享对象
        share = new Share(api);
        //支付对象
        pay = new Pay(api);
        //小程序类
        miniProgram = new MiniProgram(api);
        //认证类
        authRequest = new AuthRequest(api);

        //初始化监听类
        IntentFilter intentFilter = new IntentFilter();
        //这个ACTION和后面activity的ACTION一样就行,要不然收不到的
        intentFilter.addAction(TAG);
        //创建监听类
        activity.registerReceiver(myBroadcastReceive, intentFilter);

    }

    @Override
    public void onDetachedFromActivityForConfigChanges() {
        this.onDetachedFromActivity();
    }

    @Override
    public void onReattachedToActivityForConfigChanges(@NonNull ActivityPluginBinding binding) {
        this.onAttachedToActivity(binding);
    }

    @Override
    public void onDetachedFromActivity() {
        activity = null;
    }


    BroadcastReceiver myBroadcastReceive = new BroadcastReceiver() {
        @Override
        public void onReceive(Context context, Intent intent) {
            JSONObject jsonObject = new JSONObject();

            try {
                jsonObject.put("type", intent.getIntExtra("type", 500));
                jsonObject.put("errCode", intent.getIntExtra("errCode", 500));
                jsonObject.put("errStr", intent.getStringExtra("errStr"));
                jsonObject.put("transaction", intent.getStringExtra("transaction"));
                jsonObject.put("openId", intent.getStringExtra("openId"));
                jsonObject.put("pluginType", intent.getStringExtra("pluginType"));

                switch (Objects.requireNonNull(intent.getStringExtra("pluginType"))) {
                    case "Auth":
                        jsonObject.put("code", intent.getStringExtra("code"));
                        jsonObject.put("state", intent.getStringExtra("state"));
                        jsonObject.put("authResult", intent.getBooleanExtra("authResult", false));
                        jsonObject.put("url", intent.getStringExtra("url"));
                        jsonObject.put("lang", intent.getStringExtra("lang"));
                        jsonObject.put("country", intent.getStringExtra("country"));
                        break;
                    case "WXLaunchMiniProgram":
                        jsonObject.put("extraData", intent.getStringExtra("extraData"));
                        break;
                    case "Pay":
                        break;
                }
            } catch (JSONException e) {
                e.printStackTrace();
            }

            channel.invokeMethod("onResp", jsonObject.toString(), new Result() {
                @Override
                public void success(@Nullable Object result) {
                    Log.i("debug", result.toString());
                }

                @Override
                public void error(String errorCode, @Nullable String errorMessage, @Nullable Object errorDetails) {

                }

                @Override
                public void notImplemented() {

                }
            });
        }
    };


}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值