【02-02】SpringMVC基于注解的應用

一、請求處理

1、常用注解

  • @RequestMapping
    • 作用:用來匹配客戶端發送的請求(用來處理URL映射,將請求映射到處理方法中),可以在類或者方法上使用。
      • 用在類上,可以將請求模塊化,避免請求方法中的映射重復。表示為當前控制器類中的所有方法添加一個前置路徑。
      • 用在方法上,表示用來匹配要處理的請求(注意:在整個項目的不同方法上不能出現URL重復的情況)。
    • 相關屬性
      • value:要匹配的請求路徑
      • method:顯示發送請求的方式(GET、POST、PUT、DELETE)
      • params:表示請求要接收的參數,如果定義了該屬性,那么發送請求時必須要攜帶該參數;
      • headers:填寫請求頭信息;
      • consumers:設置接收的請求的內容類型,相當于指定Content-type;
      • produces:設置返回的內容類型;
       @RequestMapping(value = "/test",method = RequestMethod.GET,params = "entname",headers = {"User‐Agent=Mozilla/5.0 (Windows NT 10.0;"})public String test(){return "/index.jsp";}
      
  • @RequestParam
    • 作用:獲取請求中的參數值
    • 相關屬性
      • value:表示要獲取的參數值;
      • required:表示請求時此參數是否必須傳遞,默認是true,如果請求中不存在該參數就會報錯,如果值為false,則不做強制要求,可有可無;
      • defaultValue:如果在使用的時沒有傳遞該參數,那么就使用定義的默認值;
    • 默認情況下,可以直接將方法中的參數名設置為跟請求中的參數名一樣,此時會默認接收請求中該參數名的參數值;
      @RequestMapping("/Hello")
      public String helloWorld(@RequestParam(value = "username",defaultValue = "開發者",required = false) String name){System.out.println("hello springmvc:"+ name);
      }
      
  • @RequestHeader
    • 作用:獲取請求頭的信息
    • 相關屬性:value、required、defaultValue
    • 如果要獲取請求頭中沒有的信息,此時會報錯;
      @RequestMapping("/header")
      public String header(@RequestHeader("User‐Agent") String agent){ System.out.println(agent);return "success";
      }
      
  • @CookieValue
    • 作用:獲取cookie中的值
    • 相關屬性:value、required、defaultValue
    • 如果要獲取cookie中沒有的信息,此時會報錯;
    • 等同于request.getCookies();
      @RequestMapping("/cookie")public String cookie(@CookieValue("JSESSIONID") String id){System.out.println(id);return "success";}
      
  • @PathVariable
    • 作用:獲取請求路徑中的參數
    • 如果是單個參數接收,必須使用@PathVariable來聲明獲取對應的參數占位符的值;
    • 如果是JavaBean,則可以省略@PathVariable,但要保證各個占位符的參數名與JavaBean中的屬性名一致;
      @RequestMapping("/user/{id}/{username}")
      public String path01(@PathVariable("id") Integerid,@PathVariable("username")String name){System.out.println(id);System.out.println(name);return "/index.jsp";
      }@RequestMapping("/user02/{id}/{name}")
      public String path02(User user){System.out.println(user);return "/index.jsp";
      }
      

2、REST風格

  • 它是一種客戶端映射到服務器資源的架構設計;
  • 它是一種針對網絡應用的設計和開發方式,可以降低開發的復雜性,提高系統的可伸縮性;
  • 是一種更優雅的URL風格;
  • 通過URL我們就可以知道這個請求是用來做什么的;
     @GetMapping("/rest/getuser/{uid}")public String getUser(@PathVariable("uid") Integer id ){System.out.println("hello springmvc GET:"+ id);return "/index.jsp";}@PostMapping("/rest/addUser")public String addUser(User user){System.out.println("hello springmvc POST:"+ user);return "/index.jsp";}@PutMapping("/rest/updateUser")public String updateUser(User user){System.out.println("hello springmvc PUT:"+ user);return "redirect:/index2.jsp";}@DeleteMapping("/rest/deleteUser/{uid}")public String deleteUser(@PathVariable("uid") Integer id ){System.out.println("hello springmvc DELETE:"+ id);return "redirect:/index2.jsp";}
    

3、靜態資源的訪問

  • 當頁面中直接使用靜態資源時,是沒辦法直接獲取到的,是因為找不到對應的mapping映射,DispatcherServlet會攔截所有的請求,而此時我們沒有對應圖片的請求處理方法。此時只需要在springmvc.xml中添加如下配置即可:
	<!--配置訪問靜態資源--><mvc:annotation-driven/><!--設置資源的映射位置:將映射地址直接指向靜態資源文件夾,springmvc不會將此映射作為handler--><mvc:resources mapping="/images/**" location="/images/"/><!--當springmvc沒有映射到某一個請求時,就會調用默認的servlet來處理--><mvc:default-servlet-handler/>

二、響應處理

1、視圖解析器

  • 默認的內置視圖解析器
 <!--默認的視圖解析器--><bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver"><property name="prefix" value="/WEB-INF/views/"/><property name="suffix" value=".jsp"/></bean>

2、視圖控制器

<!--視圖控制器:設置某個路徑映射到指定的jsp頁面--><mvc:view-controller path="/" view-name="index"></mvc:view-controller>

3、使用Model,Map,ModelMap傳輸數據到頁面

  • 當使用以下三種方式設置之后,所有的參數值都設置到了request的作用域中;
  • ${requestScope.type}
  /*** 通過Servlet原生API將數據傳輸到視圖中* @param request* @return*/@RequestMapping("/servlet")public String servletApi(HttpServletRequest request){request.setAttribute("type","servletAPI");return "main";}/*** 通過Model將數據傳輸到視圖中* @param model* @return*/@RequestMapping("/model")public String modelAttribute(Model model){model.addAttribute("type","modelAttribute");return "main";}/*** 通過ModelMap將數據傳輸到視圖中* @param modelMap* @return*/@RequestMapping("/modelMap")public String modelMapAttribute(ModelMap modelMap){modelMap.addAttribute("type","modelMapAttribute");return "main";}/*** 通過Map將數據傳輸到視圖中* @param map* @return*/@RequestMapping("/map")public String map(Map map){map.put("type","map");return "main";}

4、使用ModelAndView對象傳輸數據到頁面

  • 使用ModelAndView對象時,返回值類型也是該對象,可以將要跳轉的頁面設置為view的名稱,來完成跳轉功能,同時,數據也是存放到了request作用域中;
  • springmvc還會隱式的將請求綁定的參數自動設置到request域中;
  /*** 通過ModelAndView將數據傳輸到視圖中* @return*/@RequestMapping("/modelAndView")public ModelAndView modelAndView(){ModelAndView modelAndView = new ModelAndView("main");modelAndView.addObject("type", "modelAndView");return modelAndView;}

5、使用session傳輸數據到頁面

  • 方式一:通過Servlet API的方式讀寫session
    • 通過參數綁定的方式去獲取Servlet API
    • 通過自動注入的方式去獲取Servlet API(推薦使用這種方式)
    • ${sessionScope.type}
 /*** 通過HttpSession將數據傳輸到視圖中* @param session* @return*/@RequestMapping("/session")public String session(HttpSession session){session.setAttribute("type","servletApi-session");return "main";}//自動注入@Autowiredprivate HttpSession session;@RequestMapping("/autoSession")public String autoSession() {session.setAttribute("type","auto-session");return "main";}
  • 方式二:通過注解的方式讀取session
    • @SessionAttributes
      • 用在類上,表示當前控制器類下的所有方法,都會將model指定的屬性寫入session。
      • 它會從model中獲取指定的屬性寫入session中。即:底層會從model中找一個叫type的屬性寫到session中,這種方式是依賴model的。
    • @SessionAttribute
      • 用在參數上,讀取session。
      • model和session是互通的:session可以通過model中去獲取寫入指定的屬性, model也會從session中自動寫入指定的屬性。
	@Controller@SessionAttributes("type")public class DTVController {@RequestMapping("/getSession")public String getSession(@SessionAttribute(value="type",required = false) String type){System.out.println(type);return "main";}}

6、轉發和重定向

  • 轉發的特點
    • a、地址欄的url從始至終都不會變
    • b、請求次數,僅只有一次
    • c、請求域中的數據不會丟失
    • d、根目錄包含了項目的訪問地址,所以,不用寫完成的訪問地址,只需要寫明轉發的視圖即可:/index2.jsp
  • 重定向的特點
    • a、地址欄的url會發生變化,第一次:初識地址(localhost:8080/springmvc/);第二次:重定向地址(localhost:8080/springmvc/index2.jsp)
    • b、請求次數,兩次
    • c、請求域中的數據會丟失,因為是不同的請求
    • d、根目錄不包含項目的訪問地址
      在這里插入圖片描述
 @RequestMapping("/Hello")public String helloWorld(@RequestParam(value = "name",defaultValue = "開發者",required = false) String name){System.out.println("hello springmvc:"+ name);//        return "index"; //默認是轉發,會自動添加前綴,所以,不需要寫前綴,直接寫視圖名即可//        return "forward:/index.jsp";  // forward 則需要自己顯示添加完整的視圖名和路徑,不會參與視圖解析器的處理return "redirect:/index2.jsp"; //重定向的視圖,必須存放在根目錄下,不能放到WEB-INF目錄下}

三、JSON處理

  • 需要添加解析json的依賴
 		<dependency><groupId>com.fasterxml.jackson.core</groupId><artifactId>jackson-core</artifactId><version>2.9.8</version></dependency><dependency><groupId>com.fasterxml.jackson.core</groupId><artifactId>jackson-databind</artifactId><version>2.9.8</version></dependency><dependency><groupId>com.fasterxml.jackson.core</groupId><artifactId>jackson-annotations</artifactId><version>2.9.0</version></dependency>

1、返回JSON數據

  • 1、加入jackjson依賴
  • 2、將jackjson的jar包加入WEB-INF的lib文件夾中
  • 3、在對應處理方法上加上@ResponseBody注解,用于標記該處理方法返回json
  • 4、或者將類上的@Controller改為@RestController注解,表示標記該類中所有的方法都返回json
  • 5、@RestController相當于 @Controller + @ResponseBody
@Controller
public class JsonController {@RequestMapping("/testJson01")@ResponseBody //如果返回值是字符串類型,則返回值以文本形式返回,而不是返回視圖邏輯名稱public String responseJson01(){System.out.println("testJson");return "json";}@RequestMapping("/testJson02")@ResponseBodypublic User responseJson02(){User user = new User();user.setId(1001);user.setName("張三");user.setAlias(new String[]{"張三豐","張無忌"});user.setBirthday(new Date());return user;}

2、獲取JSON數據

  • 使用@RequestBody來接收前端發送的json數據
	@RequestMapping("/testJson03")@ResponseBodypublic User responseJson03(@RequestBody User user){User user2 = new User();user.setId(1002);user.setName("張三");user.setAlias(new String[]{"張三豐","張無忌"});user.setBirthday(new Date());System.out.println(user);return user2;}

四、文件上傳和下載

1、文件下載

  • 使用Servlet原生API實現文件下載
 @RequestMapping("/download")public void downLoad(HttpServletRequest request, HttpServletResponse response) throws IOException {//獲取要下載的文件的絕對路徑String realPath = request.getServletContext().getRealPath("/images/123.png");//根據文件路徑封裝成文件對象File tmpFile=new File(realPath);//獲取文件名稱String fileName = tmpFile.getName();//設置響應頭 content‐disposition,就是設置文件下載的打開方式,默認會在瀏覽器上打開,設置UTF-8,如果文件名稱有中文,不會亂碼response.setHeader("content-disposition", "attachment;filename="+ URLEncoder.encode(fileName, "UTF-8"));//獲取文件輸入流InputStream in = Files.newInputStream(Paths.get(realPath));int len = 0;//創建緩沖區byte[] buffer = new byte[1024];//獲取輸出流OutputStream out = response.getOutputStream();//循環讀取文件,每次讀1KB,防止內存溢出while ((len = in.read(buffer)) > 0) {//將緩沖區的數據輸出到客戶端瀏覽器out.write(buffer,0,len);}in.close();}

2、文件上傳

  • Spring MVC 為文件上傳提供了直接的支持,這種支持是通過 MultipartResolver 實現的。Spring 用 Jakarta Commons FileUpload 技術實現了一個 MultipartResolver 實現類:CommonsMultipartResovler。
  • Spring MVC 上下文中默認沒有裝配 MultipartResovler,因此默認情況下不能處理文件的上傳工作,如果想使用 Spring 的文件上傳功能,需現在上下文中配置 MultipartResolver。
  • 添加Jakarta Commons FileUpload的依賴支持
	<dependency><groupId>commons-fileupload</groupId><artifactId>commons-fileupload</artifactId><version>1.4</version></dependency>
  • 配置MultipartResolver文件上傳解析器
	<bean class="org.springframework.web.multipart.commons.CommonsMultipartResolver" id="multipartResolver"><!--設置編碼,避免中文亂碼--><property name="defaultEncoding" value="UTF-8"/><!--設置上傳文件的大小--><property name="maxUploadSize" value="#{1024*1024*10}"/></bean>
  • 代碼實現
 	@RequestMapping("/upload")public String upload(@RequestParam("desc") String desc,@RequestParam("uploadFile") MultipartFile multipartFile) throws IOException {System.out.println("des:" + desc);System.out.println("uploadFile:" + multipartFile.getOriginalFilename());if (!multipartFile.isEmpty()) {//獲取文件上傳的絕對路徑String realPath = "C:\\Users\\TRS\\Desktop\\Out";//獲取文件名稱String fileName = multipartFile.getOriginalFilename();//創建文件對象File tmpFile;if (fileName != null) {tmpFile = new File(realPath, fileName);//將文件寫入到指定目錄multipartFile.transferTo(tmpFile);}}return "Success";}

五、攔截器

1、實現過程

  • SpringMVC攔截器采用AOP的設計思想,它跟過濾器類似,用來攔截處理方法在之前或者之后執行一些跟主業務沒有關系的公共功能。 比如:權限控制、日志記錄、異常記錄等
  • 實現攔截器的步驟:
    • 1、實現接口:HandlerInterceptor
    • 2、重寫三個方法:preHandle、postHandle、afterCompletion
    • 3、在springmvc.xml的配置文件中裝配攔截器
  • preHandle(HttpServletRequest request, HttpServletResponse response, Object handler)
    • 預處理回調方法,實現處理器方法的預處理(如:登錄檢查);
    • 第三個參數為響應的處理器返回值;
    • true 表示放行,繼續向下執行(如調用下一個攔截器或處理器);
    • false 表示攔截(如登錄檢查失敗),終止執行。此時我們需要通過response來產生響應;
  • postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView)
    • 后處理回調方法,實現處理器的后處理(但在渲染視圖之前);
    • 此時我們可以通過modelAndView(模型和視圖對象)對模型數據進行處理或對
      視圖進行處理,modelAndView也可能為null;
  • afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex)
    • 請求處理完畢后回調方法,在視圖渲染完后執行;
    • 如性能監控中我們可以在此記錄結束時間并輸出消耗時間,還可以進行一些資源清
      理,類似于try-catch-finally中的finally,但僅當上面的preHandle方法返回true時才會執行。
  • 自定義攔截器
@Component
public class MyInterceptor implements HandlerInterceptor {/*** 執行1【Controller執行器中的處理方法執行之前執行】* @param request 可以在方法請求之前更改request中的屬性值* @param response* @param handler 處理器對象,封裝了當前這個處理方法的信息* @return*/public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) {System.out.println("============>>>>preHandle()方法執行");//在請求映射到對應的處理方法映射時,實現類才是HandlerMethod,如果是視圖控制器,則實現類是ParameterizableViewControllerHandlerMethod handlerMethod = (HandlerMethod) handler;System.out.println("處理方法所在類:"+handlerMethod.getBean().getClass().getName());System.out.println("處理方法的方法名:"+handlerMethod.getMethod().getName());System.out.println("處理方法的參數:" + Arrays.toString(handlerMethod.getMethod().getParameters()));return true; //返回true表示放行,返回false表示攔截}/*** 執行2【Controller執行器中的處理方法執行之后,此時還沒渲染視圖】* 當處理方法出現異常時,則不會執行該方法* @param request* @param response 可以在方法執行之后去更改response中的信息* @param handler* @param modelAndView 封裝了model和視圖信息,當請求結束后可以去修改model中的數據或者視圖信息* @throws Exception*/public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, @Nullable ModelAndView modelAndView) throws Exception {System.out.println("=========>>>postHandle()方法執行");}/*** 執行3【DispacherServlet執行之后,渲染視圖之后執行】* 如果preHandle返回false,則不會執行該方法* @param request* @param response* @param handler* @param ex 在該方法中做一些記錄異常日志的功能* @throws Exception*/public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, @Nullable Exception ex) throws Exception {System.out.println("==========>>>afterCompletion()方法執行");}
}
  • 裝配攔截器
 <!--配置攔截器--><mvc:interceptors><!--它會攔截SpringMVC所有的請求--><bean class="org.example.interceptor.MyInterceptor"></bean></mvc:interceptors>

2、攔截器與過濾器的區別

  • 過濾器是基于函數回調的,而攔截器是基于java反射的;
  • 過濾器依賴于servlet容器,而攔截器不依賴與Servlet容器,依賴于SpringMVC;
  • 過濾器幾乎對所有的請求都可以起作用,而攔截器只能對SpringMVC請求起作用;
  • 攔截器可以訪問處理方法的上下文,而過濾器不可以;
    環圖
    執行過程

3、使用攔截器實現登錄權限攔截

  • 自定義用戶登錄攔截器
public class UserInterceptor implements HandlerInterceptor {@Overridepublic boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {HttpSession session = request.getSession();System.out.println("當前用戶名:"+ session.getAttribute("username"));if (!"張三".equals(session.getAttribute("username"))) {//重定向到登錄頁面response.sendRedirect(request.getContextPath() + "/login");return false;}else {return true;}}}
  • 設置攔截請求映射
<!--配置攔截器--><mvc:interceptors><!--直接配置一個bean它會攔截SpringMVC所有的請求--><bean class="org.example.interceptor.MyInterceptor"></bean><!--如果不需要攔截所有的請求,可以單獨配置--><mvc:interceptor><!--需要攔截的請求--><mvc:mapping path="/**"/><!--不需要攔截的請求--><mvc:exclude-mapping path="/login"/><!--攔截器--><bean class="org.example.interceptor.UserInterceptor"></bean></mvc:interceptor></mvc:interceptors>

六、異常處理

1、內置異常處理解析器

  • 在SpringMVC中擁有一套非常強大的異常處理機制,SpringMVC通過HandlerExceptionResolver處理程序的異常,包括請求映射、數據綁定以及目標方法執行時發生的異常。
  • 通過@ExceptionHandler可以在方法中記錄日志,并轉發到一個友好的界面進行提示;
@Controller
public class ExceptionController {@RequestMapping("/hello")public String testException(@RequestParam(value = "name") String name) {System.out.println("方法執行中...");return "index";}//只能處理當前處理器類的異常,但是優先級要比全局異常處理器高@ExceptionHandler(value = {Exception.class})public ModelAndView handleException(Exception e) {ModelAndView mv = new ModelAndView();mv.setViewName("exception");mv.addObject("ex", e);System.out.println(e.getMessage());return mv;}
}

2、全局統一異常處理

  • 如果想要對所有的控制器類進行統一異常處理,可以通過@ControllerAdvice注解來實現。
  • @ControllerAdvice 是Spring3.2提供的新注解,它是對Controller的增強,可對Controller中被 @RequestMapping注解標識的方法加一些邏輯處理: 全局異常處理、全局數據綁定、全局數據預處理;
  • 全局異常處理的實現步驟:
    • 添加@ControllerAdvice注解
    • 添加@ExceptionHandler注解
    • 處理器中自己的異常處理器優先級高于全局異常處理
    • 如果處理器類中存在異常處理方法,則優先使用處理器異常處理方法,否則,使用全局異常處理中的異常(精準異常 > 全局異常)
  • 統一異常處理:同時處理普通請求和ajax請求
    • 普通請求:返回ModelAndView對象,跳轉到指定頁面
    • ajax請求:返回json數據
	@ControllerAdvicepublic class GolablExceptionController {@ExceptionHandler(value = {Exception.class})public ModelAndView handleException(HttpServletRequest request, HttpServletResponse response, HandlerMethod handler, Exception e) {System.out.println("全局異常處理");ModelAndView mv = new ModelAndView();//1、根據用戶請求的處理方法,判斷是否是ajax請求RestController restAnnotation = handler.getClass().getAnnotation(RestController.class);//獲取類上某個注解ResponseBody resAnnotation = handler.getMethod().getAnnotation(ResponseBody.class);//獲取方法上某個注解//2、可以根據請求頭中的類型,判斷是否是ajax請求,即:Content-Type是否包含 application/jsonif (restAnnotation != null || resAnnotation != null) {//ModelAndView支持返回jsonmv = new ModelAndView(new MappingJackson2JsonView());mv.addObject("方法名", handler.getMethod().getName());mv.addObject("ex", e.getMessage());mv.addObject("code", HttpStatus.INTERNAL_SERVER_ERROR.value());}else {//返回視圖mv.setViewName("exception");mv.addObject("ex", e);StringWriter stringWriter = new StringWriter();PrintWriter printWriter = new PrintWriter(stringWriter);e.printStackTrace(printWriter);System.out.println(stringWriter); //日志記錄}return mv;}

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/36227.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/36227.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/36227.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

【Java Web】三大域對象

目錄 一、域對象概述 二、三大域對象 三、域對象使用相關API 一、域對象概述 一些可用于存儲數據和傳遞數據的對象被稱為域對象&#xff0c;根據傳遞數據范圍的不同&#xff0c;我們稱之為不同的域&#xff0c;不同的域對象代表不同的域&#xff0c;共享數據的范圍也不同。 二、…

【小紅書標題打造】規則+底層邏輯解析|輔助工具|爆款必備

前言 大家好&#xff0c;我是一名自媒體工具人&#xff0c;今天不是教大家去自己寫標題&#xff08;現在這個時代自己寫真沒必要&#xff09;而是教大家了解爆款標題的相關知識以及辨別。后面會附贈 安裝此文規則生成標題的輸出工具。在這個工具發展龐大的時代&#xff0c;如果…

【知識圖譜系列】一步步指導:安裝與配置JDK和Neo4j的完美搭配

本文將提供詳細的步驟&#xff0c;介紹如何下載、安裝和配置Java開發工具包&#xff08;JDK&#xff09;以及流行的圖形數據庫Neo4j。將從選擇合適的JDK版本開始&#xff0c;然后是下載和配置環境變量&#xff0c;接著以同樣的方式處理Neo4j。最后&#xff0c;會通過一些檢查步…

Windows應急響應靶機 - Web3

一、靶機介紹 應急響應靶機訓練-Web3 前景需要&#xff1a;小苕在省護值守中&#xff0c;在靈機一動情況下把設備停掉了&#xff0c;甲方問&#xff1a;為什么要停設備&#xff1f;小苕說&#xff1a;我第六感告訴我&#xff0c;這機器可能被黑了。 這是他的服務器&#xff…

【CSS in Depth 2 精譯】1.6 本章小結

1.6 本章小結 瀏覽器遵循層疊規則來確定哪些樣式在哪些元素上生效&#xff1b;選擇器優先級由選擇器中的 id 數、class 類的個數以及標簽名的個數來共同確定。優先級更高的聲明將覆蓋較低聲明&#xff1b;當某些屬性沒有層疊值時&#xff0c;它們會從父元素繼承一個樣式值。這…

YouCompleteMe插件安裝方法簡述

一、前言 YouCompleteMe是VIM中進行C/C 開發的重要工具&#xff0c;可以極大提升linux下C/C開發效率。 YCM需要高版本的gcc (8.0以上版本&#xff0c;支持C17) 和 vim&#xff08;8.0以上&#xff0c;支持python3.6以上&#xff09; 二、編譯gcc_8.3 1. 獲取源碼 wget https:…

Shopee API接口——獲取商家店鋪商品列表

一、引言 在跨境電商領域&#xff0c;Shopee作為東南亞地區領先的電商平臺&#xff0c;為眾多商家提供了廣闊的市場和豐富的銷售機會。本文將詳細介紹如何通過Shopee API獲取商家店鋪商品列表&#xff0c;并探討其應用場景。 二、核心功能介紹 Shopee API獲取商家店鋪商品列…

HarmonyOS NEXT Developer Beta1中的Kit

從HarmonyOS NEXT Developer Preview1&#xff08;API 11&#xff09;版本開始&#xff0c;HarmonyOS SDK以Kit維度提供豐富、完備的開放能力&#xff0c;涵蓋應用框架、系統、媒體、圖形、應用服務、AI六大領域&#xff0c;例如&#xff1a; 應用框架相關Kit開放能力&#xff…

轉行大數據開發:知識、能力及學習路線詳解

引言 隨著數據量的爆炸性增長&#xff0c;大數據開發已經成為IT行業中的熱門職業。對于希望轉行進入大數據開發領域的專業人士來說&#xff0c;了解需要掌握的知識和技能&#xff0c;并制定清晰的學習路線至關重要。本文將詳細解析轉行大數據開發所需的知識體系、能力要求及學…

Studying-代碼隨想錄訓練營day21| 669.修建二叉搜索樹、108.將有序數組轉換為二叉搜索樹、538.把二叉搜索樹轉換為累加樹、二叉樹總結

第21天&#xff0c;二叉樹最后一篇&#xff0c;沖&#x1f4aa; 目錄 669.修建二叉搜索樹 108.將有序數組轉換為二叉搜索樹 538.把二叉搜索樹轉換為累加樹 二叉樹總結 669.修建二叉搜索樹 文檔講解&#xff1a;代碼隨想錄修建二叉搜索樹 視頻講解&#xff1a;手撕修建二叉…

【PySide6】Repeater 子控件分析

文章目錄 前言分析 前言 修改 Column 控件下使用 Repeater 生成的子控件&#xff0c;但是沒有 id 無法操作&#xff0c;使用 children 層層遞歸分析 分析 QML 代碼 // https://doc.qt.io/qt-6/qml-qtquick-column.htmlColumn {id: columnspacing: 2// 定義模型property var …

代碼隨想錄算法訓練營刷題復習10:二叉樹、二叉搜索樹復習2

二叉樹、二叉搜索樹 力扣題復習 110. 平衡二叉樹257. 二叉樹的所有路徑404. 左葉子之和513. 找樹左下角的值112.路徑之和113.路經總和ii450. 刪除二叉搜索樹中的節點701. 二叉搜索樹中的插入操作 110. 平衡二叉樹 左右子樹高度差要小于1 ->遞歸調用&#xff08;need新的函…

API-元素尺寸與位置

學習目標&#xff1a; 掌握元素尺寸與位置 學習內容&#xff1a; 元素尺寸與位置仿京東固定導航欄案例實現bilibili點擊小滑塊移動效果 元素尺寸與位置&#xff1a; 使用場景&#xff1a; 前面案例滾動多少距離&#xff0c;都是我們自己算的&#xff0c;最好是頁面滾動到某個…

[leetcode]圓圈中最后剩下的數字/ 破冰游戲

. - 力扣&#xff08;LeetCode&#xff09; class Solution {int f(int num, int target) {if (num 1) {return 0;}int x f(num - 1, target);return (target x) % num;} public:int iceBreakingGame(int num, int target) {return f(num, target);} };

程序猿大戰Python——Python與MySQL交互一

pymysql模塊的安裝 目標&#xff1a;了解如何安裝pymysql模塊&#xff1f; 當要使用Python和MySQL數據庫進行交互&#xff0c;需要借助一個第三方模塊&#xff1a;pymysql。 在使用pymysql模塊前&#xff0c;先進行安裝&#xff1a; pip install pymysql 有時使用pip instal…

從零開始做題:有手就行

1 題目 2 解題 ARPHCR工具破解 得到flag DASCTF{2b3767763885a019b65bbfe9d1136c3b}

數據結構與算法筆記:高級篇 - 向量空間:如何實現一個簡單的音樂推薦系統?

概述 很多人喜都喜愛聽歌&#xff0c;以前我們用 MP3 聽歌&#xff0c;現在直接通過音樂 App 在線就能聽歌。而且&#xff0c;各種音樂 App 的功能越來越強大&#xff0c;不僅可以自己選歌聽&#xff0c;還可以根據你聽歌的喜好&#xff0c;給你推薦你可能會喜好的音樂&#x…

【WEB前端2024】3D智體編程:喬布斯3D紀念館-第49課-機器人自動跳舞

【WEB前端2024】3D智體編程&#xff1a;喬布斯3D紀念館-第49課-機器人自動跳舞 使用dtns.network德塔世界&#xff08;開源的智體世界引擎&#xff09;&#xff0c;策劃和設計《喬布斯超大型的開源3D紀念館》的系列教程。dtns.network是一款主要由JavaScript編寫的智體世界引擎…

DevExpress Office File API教程 - 如何使用AI服務增強Word文檔可訪問性和語言支持?

DevExpress Office File API是一個專為C#, VB.NET 和 ASP.NET等開發人員提供的非可視化.NET庫。有了這個庫&#xff0c;不用安裝Microsoft Office&#xff0c;就可以完全自動處理Excel、Word等文檔。開發人員使用一個非常易于操作的API就可以生成XLS, XLSx, DOC, DOCx, RTF, CS…

使用隱式事件執行控制圖

什么是隱式事件&#xff1f; 隱式事件是圖表執行時發生的內置事件&#xff1a; 圖表喚醒 進入一個狀態 退出狀態 分配給內部數據對象的值 這些事件是隱式的&#xff0c;因為您沒有顯式地定義或觸發它們。隱式事件是它們發生的圖表的子級&#xff0c;僅在父圖表中可見。 隱式事…