Android 网络编程-网络请求

news2024/11/23 23:02:09

Android 网络编程-网络请求

文章目录

  • Android 网络编程-网络请求
    • 一、主要内容
    • 二、开发网络请求前的基本准备
      • 1、查看需要请求的网址是否有效
        • (1)通过网页在线验证
        • (2)使用专用window网咯请求工具
        • (3)编写app代码验证
      • 2、学会把服务器的json数据转换成Bean对象
      • 3、具体效果测试
        • 简单测试的网址:
          • 天气api:
          • apipost调试网址
        • (1)get请求,在浏览器窗口栏请求的显示
        • (2)get请求在在线请求网址的显示
        • (3)post请求在在线请求的的网址显示
        • (4)json数据在线转换成Bean对象
        • 应用app效果显示;
    • 三、代码介绍
      • 1、普通网络请求
        • (1)get网络请求
        • (2)Post网络请求
      • 2、使用OkHttp网络框架请求网络
        • (1)Get网络请求
        • (2)Post网络请求
      • 3、使用Retrofit网络框架请求网络
        • (1)Get网络请求
          • ①创建请求接口对象
          • ② 具体的请求代码
        • (2)Post网络请求
          • ①创建请求接口对象
          • ② 具体的请求代码
      • 4、使用WebView显示对应网址的网页
        • (1)在布局文件写入控件WebView
        • (2) 设置基本参数
    • 三、总结
      • 1、网络请求是要在子线程内进行
      • 2、不同框架的网络请求根据项目具体情况使用
      • 3、Android 网络编程要学习些什么
        • (1)网络分层和HTTP协议基本知识,比如请求报文和响应报文
        • (2)Java网络编程基础,TCP/UDP 进行连接交互
        • (3)Json数据转Gson对象
        • (4)Android基本网络请求和基本网络框架使用
        • (5)加密算法:数据加密和解密

本文介绍一下Android 网络请求,开发了简单demo,适合Android入门人员学习。

为啥要写这个??给应届生看的。。。

一、主要内容

1、开发网络请求前的基本准备
2、普通网络请求代码
3、使用OkHttp网络框架请求网络代码
4、使用Retrofit网络框架请求网络代码
5、使用WebView显示对应网址的网页
6、应用demo的相关代码和apk

二、开发网络请求前的基本准备

1、查看需要请求的网址是否有效

(1)通过网页在线验证

能验证get请求和简单的post 请求,比如只设置几个参数的post请求
在线get/post请求测试(里面还有一系列工具):
http://www.jsons.cn/httpurl/
http://coolaf.com/

//可以简单模拟 get/post返回的数据
https://v7.apipost.cn/#/apis/design

(2)使用专用window网咯请求工具

① PostMan
② Apifox (国内自研,PostMan加强版,支持网页和桌面工具)
https://apifox.com/#pricing

(3)编写app代码验证

一般用于验证文件上传的情况,
也可以用windows 工具进行验证,Apifox 也是支持文件上传的。

2、学会把服务器的json数据转换成Bean对象

在线转换Json格式转换JAVA实体Bean类:
http://www.jsons.cn/json2java/

作用?
把字符串的数据赋值到对象,使用的时候直接使用 Object.getXXX 获取返回的某个信息。

也可以使用Android Studio 插件:GsonFormat

3、具体效果测试

get请求测试,可以找网上天气网址的api或者笑话类的api网址;
post请求测试,可以找地图类的api(百度地图),或者语音类的api网址(讯飞)。

简单测试的网址:

天气api:

提供天气,气象查询:https://www.yiketianqi.com/index/doc
get请求网址;
https://v0.yiketianqi.com/api?unescape=1&version=v61&appid=28392918&appsecret=No9zfo8f&adcode=440307000000

apipost调试网址

提供get/post简单调试功能:https://v7.apipost.cn/#/apis/design
注册登陆后,看起来是可以设计返回的数据的,估计是操作要麻烦一点,有需要的可以自己研究。

post请求网址:
https://demo-api.apipost.cn/api/demo/login
mobile=18289454846&ver_code=123456

(1)get请求,在浏览器窗口栏请求的显示

在这里插入图片描述

(2)get请求在在线请求网址的显示

在这里插入图片描述

(3)post请求在在线请求的的网址显示

post 请求在浏览器输入行直接是无法请求到数据的,只能使用专业的网址或者工具 获取post请求的数据。

在这里插入图片描述

(4)json数据在线转换成Bean对象

在这里插入图片描述

应用app效果显示;

主界面:
在这里插入图片描述

普通网络请求:

在这里插入图片描述

OkHttp网络请求:
在这里插入图片描述

retrofit网络请求:
在这里插入图片描述
为啥这里TextView显示的不对,大家可以在代码里面看看。

WebView界面:
在这里插入图片描述

应用demo里面显示了很多WebView界面,这里只展示其中一个。

代码资源下载地址:

https://download.csdn.net/download/wenzhi20102321/88215651

三、代码介绍

1、普通网络请求

网络请求一定要在子线程执行,否则会报错。
数据返回后要显示在界面上要切换回主线程。

(1)get网络请求

    //get方法请求网络
    public void getNetwork(View view) {
        GET_UTL = et_url_get.getText().toString();
        LogUtil.debugInform("GET_UTL = " + GET_UTL);
        //创建线程,请求网络
        new Thread(new Runnable() {
            @Override
            public void run() {
                // 创建一个URL对象
                URL url = null;
                try {
                    url = new URL(GET_UTL);

                    // 创建一个HttpURLConnection对象,并设置请求方法为GET
                    HttpURLConnection connection = null;
                    connection = (HttpURLConnection) url.openConnection();
                    connection.setRequestMethod("GET");
                    connection.setConnectTimeout(5000);
                    // 获取服务器响应的状态码
                    int responseCode = 0;
                    responseCode = connection.getResponseCode();
                    if (responseCode == HttpURLConnection.HTTP_OK) {
                        // 读取服务器响应的数据
                        BufferedReader reader = new BufferedReader(new InputStreamReader(connection.getInputStream()));
                        StringBuilder response = new StringBuilder();
                        String line;
                        while ((line = reader.readLine()) != null) {
                            response.append(line); //把读取的数据不断放入response对象中
                        }
                        reader.close();
                        // 在UI线程中更新UI  runOnUiThread
                         String responseData = response.toString();
                

                    }


                } catch (Exception e) {
                    e.printStackTrace();
                    LogUtil.error("", e);
                }


            }
        }).start();

    }

(2)Post网络请求


  //post方法请求王网络
    public void postNetwork(View view) {
       
        //创建线程,请求网络
        new Thread(new Runnable() {
            @Override
            public void run() {
                // 创建一个URL对象
                URL url = null;
                try {
                    url = new URL(POST_UTL);

                    // 创建一个HttpURLConnection对象,并设置请求方法为GET
                    HttpURLConnection connection = null;
                    connection = (HttpURLConnection) url.openConnection();
                    connection.setConnectTimeout(5000);

                    //------------------------------ 区别和Get方法 ,Start
                    connection.setRequestMethod("POST");

                    // 启用输出流,以便向服务器发送数据
                    connection.setDoOutput(true);

                    // 创建一个输出流对象,并将数据写入输出流
                    OutputStream outputStream = connection.getOutputStream();
                    String postData = POST_MESSAGE;
                    outputStream.write(postData.getBytes());
                    outputStream.flush();
                    outputStream.close();
                    //------------------------------ 区别和Get方法 ,End

                    // 获取服务器响应的状态码
                    int responseCode = connection.getResponseCode();
                    if (responseCode == HttpURLConnection.HTTP_OK) {
                        // 读取服务器响应的数据
                        BufferedReader reader = new BufferedReader(new InputStreamReader(connection.getInputStream()));
                        StringBuilder response = new StringBuilder();
                        String line;
                        while ((line = reader.readLine()) != null) {
                            response.append(line); //把读取的数据不断放入response对象中
                        }
                        reader.close();
                        // 在UI线程中更新UI
                         // 处理服务器响应的数据
                        String responseData = response.toString();

                    }


                } catch (Exception e) {
                    e.printStackTrace();
                    LogUtil.error("", e);
                }


            }
        }).start();
    }

2、使用OkHttp网络框架请求网络

(1)Get网络请求


    //get方法请求网络
    public void getNetwork(View view) {
    
        Request request = new Request.Builder()
                .url(GET_UTL)
                .get() //默认为get ,不设置也行
                .build();
        Call call = client.newCall(request);
        //网络请求的回调
        call.enqueue(new Callback() {
            @Override
            public void onFailure(@NonNull Call call, @NonNull IOException e) {
                Toast.makeText(OkhttpNetworkActivity.this, "请求错误:" + e.getMessage(), Toast.LENGTH_LONG).show();
            }

            @Override
            public void onResponse(@NonNull Call call, @NonNull Response response) throws IOException {
                // 处理服务器响应的数据
                String responseData = response.body().string();
                LogUtil.debugInform("responseData = " + responseData);
                // TODO: 在这里处理服务器响应的数据

            }
        });


    }

(2)Post网络请求


    //post方法请求王网络
    public void postNetwork(View view) {
        //创建网络处理的对象
        OkHttpClient client = new OkHttpClient.Builder()
                .readTimeout(5, TimeUnit.SECONDS)
                .build();

        //mobile=18289454846&ver_code=123456
        //post请求来获得数据
        //创建一个RequestBody,存放重要数据的键值对
        RequestBody body = new FormBody.Builder()
                .add("mobile", "18289454846")
                .add("ver_code", "123456").build();
        //创建一个请求对象,传入URL地址和相关数据的键值对的对象
        Request request = new Request.Builder()
                .url(POST_UTL)
                .post(body).build();

        //创建一个能处理请求数据的操作类
        Call call = client.newCall(request);

        //使用异步任务的模式请求数据
        call.enqueue(new Callback() {
            @Override
            public void onFailure(Call call, IOException e) {
                LogUtil.error("", e);
            }

            @Override
            public void onResponse(Call call, Response response) throws IOException {

                // 在UI线程中更新UI
                 String responseData = response.body().string();
                 LogUtil.debugInform("result = " + responseData);

            }
        });

    }


3、使用Retrofit网络框架请求网络

(1)Get网络请求

请求示例网址:
https://v0.yiketianqi.com/api?unescape=1&version=v61&appid=28392918&appsecret=No9zfo8f&adcode=440307000000

①创建请求接口对象
package com.example.networkdemo.retrofit;


import com.example.networkdemo.bean.WeatherBean;

import retrofit2.Call;
import retrofit2.http.GET;
import retrofit2.http.Query;

/**
 * Get请求
 * 这里使用get请求的方式请求数据
 * 并且到的是字符串数据
 */
public interface RetrofitWeatherService {
    //键值对的定义和数据的返回类型的定义这里是String
    //https://v0.yiketianqi.com/api?unescape=1&version=v61&appid=28392918&appsecret=No9zfo8f&adcode=440307000000
    //这里使用 @Field 是会报错,是要使用 @Query
    @GET("api")//get请求方式
    Call<WeatherBean> getWeather(@Query("unescape") String unescape, @Query("version") String version,
                                 @Query("appid") String appid, @Query("appsecret") String appsecret, @Query("adcode") String adcode);
}


② 具体的请求代码

比如在某个Activity写如下代码


    //get方法请求网络
    public void getNetwork(View view) {

        Retrofit retrofit = getGsonRetrofit(GET_UTL);

        RetrofitWeatherService weatherService = retrofit.create(RetrofitWeatherService.class);
        //?unescape=1&version=v61&appid=28392918&appsecret=No9zfo8f&adcode=440307000000"
        Call<WeatherBean> call = weatherService.getWeather("1", "v61", "28392918", "No9zfo8f", "440307000000");
        //转换成Call,在call对象包含Url的完整地址
        //可以看到这里使用了create的方法,里面传入了请求服务的接口类
        //并且后面接的是接口类的方法,方法里面传入Url地址要的键值对的值
        //这时call对象就有完整的Url地址,就可以请求数据了
        //使用call对象进行网络数据请求
        call.enqueue(new Callback<WeatherBean>() {
            //网络数据请求成功的回调方法
            @Override
            public void onResponse(Call<WeatherBean> call, Response<WeatherBean> response) {

                runOnUiThread(new Runnable() {
                    @Override
                    public void run() {
                        WeatherBean bean = response.body();
                        tv_info.setText(TimeUtil.getTimeString() + " \n Get请求的数据:" + bean + "");
                        String air_tips = bean.getAir_tips();
                        String update_time = bean.getUpdate_time();
                        String tem1 = bean.getTem1();
                        String tem2 = bean.getTem2();
                        String tem = bean.getTem();
                        Toast.makeText(RetrofitNetworkActivity.this, "天气时间:" + update_time
                                + "\n 当前温度:" + tem + ",温度变化" + tem2 + "--" + tem1 +
                                "\n 温馨提示:" + air_tips, Toast.LENGTH_LONG).show();
                    }
                });
            }

            //网络数据请求失败的回调方法
            @Override
            public void onFailure(Call<WeatherBean> call, Throwable t) {
                tv_info.setText(TimeUtil.getTimeString() + " \n Get 请求的失败日志:" + t.getMessage() + "");
            }
        });

    }

(2)Post网络请求

Post请求网址:https://demo-api.apipost.cn/api/demo/login
携带信息:mobile=18289454846&ver_code=123456

①创建请求接口对象
package com.example.networkdemo.retrofit;



import com.example.networkdemo.bean.LoginBean;

import retrofit2.Call;
import retrofit2.http.Field;
import retrofit2.http.FormUrlEncoded;
import retrofit2.http.POST;

/**
 * 登陆服务器的请求
 * 这里使用post请求的方式请求数据
 * 并且到的是一个自定义的对象数据
 */
public interface RetrofitLoginService {
    //https://demo-api.apipost.cn/api/demo/login
    @POST("api/demo/login")//Post请求方式
    @FormUrlEncoded      //键值对的定义和数据的返回类型的定义这里是String
    Call<LoginBean> login(@Field("mobile") String mobile, @Field("ver_code") String ver_code);
}

② 具体的请求代码

    //post方法请求王网络
    public void postNetwork(View view) {
      
        Retrofit retrofit = getGsonRetrofit(POST_UTL); //https://demo-api.apipost.cn/
        RetrofitLoginService loginService = retrofit.create(RetrofitLoginService.class);
        Call<LoginBean> call = loginService.login("18289454846", "123456");
        call.enqueue(new Callback<LoginBean>() {
            @Override
            public void onResponse(Call<LoginBean> call, Response<LoginBean> response) {
                // 在UI线程中更新UI
                runOnUiThread(new Runnable() {
                    @Override
                    public void run() {
                        // 处理服务器响应的数据
                        LoginBean loginBean = response.body();
                        LogUtil.debugInform("loginBean = " + loginBean);
                        int code = loginBean.getCode();
                        LoginBean.DataBean data = loginBean.getData();
                        String msg = loginBean.getMsg();
                        Toast.makeText(RetrofitNetworkActivity.this, "登陆信息:" +
                                "\n code = " + code + ", msg = " + msg, Toast.LENGTH_LONG).show();
                        LogUtil.debugInform("data getToken = " + data.getToken());

                        // TODO: 在这里处理服务器响应的数据
                        tv_info.setText(TimeUtil.getTimeString() + " \n Post请求的数据:" + response + "");
                    }
                });
            }

            @Override
            public void onFailure(Call<LoginBean> call, Throwable t) {
                runOnUiThread(new Runnable() {
                    @Override
                    public void run() {
                        tv_info.setText(TimeUtil.getTimeString() + " \n Post请求的失败日志:" + t.getMessage() + "");
                    }
                });
            }
        });
    }


    //返回一个Gson类型的对象
    public Retrofit getGsonRetrofit(String url) {
        Retrofit retrofit = new Retrofit.Builder().baseUrl(url)
                .addConverterFactory(GsonConverterFactory.create())
                .build();
        return retrofit;
    }


    //返回一个Gson类型的字符串,
    public Retrofit getStringRetrofit(String url) {
        Retrofit retrofit = new Retrofit.Builder().baseUrl(url)
                .addConverterFactory(ScalarsConverterFactory.create())
                .build();
        return retrofit;
    }


4、使用WebView显示对应网址的网页

(1)在布局文件写入控件WebView

   <WebView
        android:id="@+id/web_view"
        android:layout_width="match_parent"
        android:layout_height="match_parent" />

(2) 设置基本参数


         web_view = findViewById(R.id.web_view);
  
        WebSettings webSettings = web_view.getSettings();
        //如果访问的页面中要与Javascript交互,则webview必须设置支持Javascript
        webSettings.setJavaScriptEnabled(true);
        webSettings.setDefaultTextEncodingName("utf-8");//设置编码格式

        //要显示的网址:
        web_view.loadUrl(url); //设置网址

这里只是基本代码,还可以设置跳转监听,前进后退网页跳转等,可以自己调试研究。

三、总结

1、网络请求是要在子线程内进行

2、不同框架的网络请求根据项目具体情况使用

如果频率很多的使用网络请求,直接使用原生请求即可,不用使用网络框架。
如果使用频率很高,可以使用健全的网络框架:OkHttp/Retrofit;
OkHttp使用简单,Retrofit 使用复杂一些,但是和很多其他框架可以结合使用,比如Gson,RxJava等。

3、Android 网络编程要学习些什么

(1)网络分层和HTTP协议基本知识,比如请求报文和响应报文

虽然不一定会用到,但是也是要知道里面的知识点。

(2)Java网络编程基础,TCP/UDP 进行连接交互

可以写demo,一个作为客户端一个作为服务端,连接后进行通讯交互。

(3)Json数据转Gson对象

网络上数据请求基本都是返回json数据,使用Gson对象可以直接转换成对应的对象,使用起来比较方便。

但是也有一些网络请求返回的数据不是json数据格式,比如xml格式,或者其他特定格式。
这个就需要自己写工具类进行解析了。

(4)Android基本网络请求和基本网络框架使用

不使用网络框架请求网络和使用主流网络框架请求网络。

(5)加密算法:数据加密和解密

因为网络数据是经过加密的,所以必须要经过解密才能读取到正常数据。
算法是会使用框架就行了的,具体算法一般人写不出来!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/876844.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

less学习语法

1.CSS函数的补充 1.rgb/rgba/translate/rotate/scale 2.非常好用的css函数&#xff1a; var:使用css定义的变量calc:计算css值&#xff0c;通常用于计算元素的大小或位置blur:毛玻璃&#xff08;高斯模糊&#xff09;效果gradient:颜色渐变函数 var:定义变量 css中可以自定…

关于青少年学习演讲与口才对未来的领导力的塑造的探析

标题&#xff1a;青少年学习演讲与口才对未来领导力的塑造&#xff1a;一项探析 摘要&#xff1a; 本论文旨在探讨青少年学习演讲与口才对未来领导力的塑造的重要性和影响。通过分析演讲和口才对青少年的益处&#xff0c;以及如何培养这些技能来促进领导力的发展&#xff0c;我…

pytest数据驱动 pandas

pytest数据驱动 pandas 主要过程&#xff1a;用pandas读取excel里面的数据&#xff0c;然后进行百度查询&#xff0c;并断言 pf pd.read_excel(data_py.xlsx, usecols[1,2])print(pf.values)输出&#xff1a;[[‘听妈妈的话’ ‘周杰伦’] [‘遇见’ ‘孙燕姿’] [‘伤心太平…

win10下如何安装ffmpeg

安装ffmpeg之前先安装win10 绿色软件管理软件&#xff1a;scoop. Scoop的基本介绍 Scoop是一款适用于Windows平台的命令行软件&#xff08;包&#xff09;管理工具&#xff0c;这里是Github介绍页。简单来说&#xff0c;就是可以通过命令行工具&#xff08;PowerShell、CMD等…

性能优化-超大图加载

超大图加载优化 网站首页的头部有时候要加载超大图&#xff0c;可能超过4M&#xff0c;如果网速不好用户会看到好长时间的白屏&#xff0c;体验非常不好。 这里使用大图缩略图的模式处理这个问题&#xff1a; 使用工具根据大图(>1M)做一个10k的缩略图图片同时加载&#xf…

这所院校性价比极高!专业课太简单了!保护一志愿!

一、学校及专业介绍 昆明理工大学&#xff08;Kunming University of Science and Technology&#xff09;&#xff0c;位于云南省昆明市&#xff0c;是国防科技工业局与云南省共建的重点大学&#xff0c;国家"特色重点学科项目"建设高校。昆工就综合实力和竞争压力…

Vue 引入 Element-UI 组件库

Element-UI 官网地址&#xff1a;https://element.eleme.cn/#/zh-CN 完整引入&#xff1a;会将全部组件打包到项目中&#xff0c;导致项目过大&#xff0c;首次加载时间过长。 下载 Element-UI 一、打开项目&#xff0c;安装 Element-UI 组件库。 使用命令&#xff1a; npm …

Camx--概述

该部分代码主要位于 vendor/qcom/proprietary/ 目录下&#xff1a; 其中 camx 代表了通用功能性接口的代码实现集合&#xff08;CamX&#xff09;&#xff0c;chi-cdk代表了可定制化需求的代码实现集合&#xff08;CHI&#xff09;&#xff0c;从图中可以看出Camx部分对上作为H…

开源项目-高校自动排课系统

哈喽,大家好,今天给大家带来一个开源项目-基于遗传算法的一个高校自动排课系统,同时也是一个前后端分离项目。 前端:React 后端:SpringBoot+MyBatis+MySQL数据库 高校自动排课系统的主要功能包括查询模块,安排教学区域,排课页面三部分 登录 查询模块 可以根据学年…

docker pull 设置代理 centos

On CentOS the configuration file for Docker is at: /etc/sysconfig/docker 用 root 权限打开 text editor sudo gedit 注意 加引号 Adding the below line helped me to get the Docker daemon working behind a proxy server: HTTP_PROXY“http://<proxy_host>:&…

学习笔记整理-DOM-01-基础知识

一、DOM基本概念 1. DOM基本概念 DOM是JS操控HTML和CSS的桥梁。DOM是JS操作HTML变得优雅。 DOM(Document Object Model&#xff0c;文档对象模型)是JavaScript操作HTML文档的接口&#xff0c;使文档操作变得非常优雅、简便。DOM最大的特点就是将文档表示为节点树。 节点的node…

spss--数据分析Log-Binonial模型

在横断面研究中&#xff0c;Log-binomial 模型能够获得研究因素与结局变量的关联强度指标患病率比&#xff08;PR&#xff09;&#xff0c;是一种研究二分类观察结果与多因素之间关系的重要方法&#xff0c;在医学研究等领域中得到了广泛的应用。 采用log-binomial 模型可直接估…

springboot整合kafka多数据源

整合kafka多数据源 项目背景依赖配置生产者消费者消息体 项目背景 在很多与第三方公司对接的时候&#xff0c;或者处在不同的网络环境下&#xff0c;比如在互联网和政务外网的分布部署服务的时候&#xff0c;我们需要对接多台kafka来达到我们的业务需求&#xff0c;那么当kafk…

塔斯汀的“中国汉堡”并不tasty

文 | 螳螂观察 作者 | 易不二 华莱士门徒 作为快餐消费市场的两大霸主——麦当劳、肯德基&#xff0c;自入华以来&#xff0c;从来不缺模仿者、挑战者。 从福建起家、已经成为了万店品牌的华莱士&#xff0c;无疑是最成功的一个。 得益于被餐饮界称之为“福建模式”的门店…

Arduino驱动红外二氧化碳传感器(气体传感器篇)

目录 1、传感器特性 2、驱动程序 红外激光传感器是将成熟的红外吸收气体检测技术与精密光路设计、精良电路设计紧密结合而制作出的高性能传感器,具有高灵敏度、高分辨率、低功耗,响应快、抗水汽干扰、不中毒、稳定性高、使用寿命长等特点。本篇博文使用Arduino驱动红外二氧…

C++ 字符串类 string

文章目录 前言一、string 类型概括二、字符串流总结 前言 在C中&#xff0c;字符串是一种常见的数据类型&#xff0c;用于存储和操作文本数据。C标准库中提供了std::string类&#xff0c;它是一个功能强大的字符串类&#xff0c;提供了丰富的方法和操作符&#xff0c;使我们能…

精挑细选的几个宝藏软件

是不是感觉你的电脑里面永远都缺少一款软件&#xff1f;每次想要使用某个功能的时候总是不能找到合适的&#xff0c;还要先去网上找&#xff0c;小编给大家分享几款超级实用的软件&#xff0c;建议低调收藏哦~ Proxyee-down/下载工具 proxyee-down是一款免费开源的http下载工…

Vue 安装开发者工具

1.下载开发者工具&#xff0c;下载地址&#xff1a;http://book.wiyp.top/App/Vue3开发者工具-谷歌/Vue3.crx 2.打开谷歌浏览器&#xff0c;点击扩展&#xff0c;点击管理扩展程序。 3.开启开发者模式&#xff0c;将 Vue3 开发者工具文件拖拽到浏览器中进行安装。 注&#xff…

构建一个LLM应用所需的所有信息

一、说明 您是否对大型语言模型&#xff08;LLM&#xff09;的潜力感兴趣&#xff0c;并渴望创建您的第一个基于LLM的应用程序&#xff1f;或者&#xff0c;也许您是一位经验丰富的开发人员&#xff0c;希望简化工作流程&#xff1f;看看DemoGPT就是您的最佳选择。该工具旨在简…