suchen
HeimJavajavaLernprogrammSo implementieren Sie das Bestell-Applet in SpringBoot

1. Funktionseinführung

Dieses Bestellsystem basiert hauptsächlich auf dem SpringBoot-Framework und kleinen Programmen. Es ist hauptsächlich darauf ausgelegt, bequemere und effizientere Dienste für das Leben der heutigen Menschen bereitzustellen Bereitstellung eines besseren Systems für das Benutzer-, Produkt-, Bestell- und andere Informationsmanagement.

Die wichtigsten vom System implementierten Funktionsmodule sind wie folgt:

Rezeption:

1) Registrieren und anmelden

# 🎜🎜#2) Persönliches Center

① Persönliche Daten ändern

② Lieferadresse ändern

③ Punkte

3 ) Produktsuche # 🎜🎜#

4) Produktsuche

5) Warenkorb

6) Zahlungs-Backend bestellen:

1 ) Registrieren und anmelden

2) Persönliches Center

① Persönliche Daten ändern

② Passwort ändern

3) Benutzerverwaltung#🎜🎜 #

①Kundeninformationsverwaltung

②Administratorinformationsverwaltung

4) Produktverwaltung

①Produktklassifizierungsverwaltung#🎜🎜 #

②Produktinformationsmanagement

③Bestand und Verkauf

5) Auftragsverwaltung

Die Rezeption bietet Benutzerregistrierungs-Login, persönliches Center, und Durchsuchen von Produkten, Suchen nach Produkten, Hinzufügen von Produkten zum Warenkorb, Bestellen und Zahlungsfunktionen. Das Backend bietet Funktionen wie Verwaltungsregistrierung und -anmeldung, Kennwortänderung, Änderung persönlicher Informationen, Verwaltung von Benutzerinformationen, Verwaltung von Administratorinformationen, Produktinformationsverwaltung, Produktverteilungsverwaltung, Bestands- und Verkaufsstatistiken, Auftragsverwaltung usw.

2. Einführung in die Entwicklungssprache

verwendet das SpringBoot+Vue+WeChat-Applet für die Entwicklung und die Datenbank verwendet MySQL.

Drei, Einführung in die Systemschnittstelle

So implementieren Sie das Bestell-Applet in SpringBoot

# 🎜🎜#So implementieren Sie das Bestell-Applet in SpringBoot

So implementieren Sie das Bestell-Applet in SpringBoot

So implementieren Sie das Bestell-Applet in SpringBootViertens: Kerncode-Demonstration

/**
 * 登录相关
 */
@RequestMapping("users")
@RestController
public class UserController{
	@Autowired
	private UserService userService;
	@Autowired
	private TokenService tokenService;
	/**
	 * 登录
	 */
	@IgnoreAuth
	@PostMapping(value = "/login")
	public R login(String username, String password, String captcha, HttpServletRequest request) {
		UserEntity user = userService.selectOne(new EntityWrapper<UserEntity>().eq("username", username));
		if(user==null || !user.getPassword().equals(password)) {
			return R.error("账号或密码不正确");
		}
		String token = tokenService.generateToken(user.getId(),username, "users", user.getRole());
		return R.ok().put("token", token);
	}
	/**
	 * 注册
	 */
	@IgnoreAuth
	@PostMapping(value = "/register")
	public R register(@RequestBody UserEntity user){
//    	ValidatorUtils.validateEntity(user);
    	if(userService.selectOne(new EntityWrapper<UserEntity>().eq("username", user.getUsername())) !=null) {
    		return R.error("用户已存在");
    	}
        userService.insert(user);
        return R.ok();
    }
	/**
	 * 退出
	 */
	@GetMapping(value = "logout")
	public R logout(HttpServletRequest request) {
		request.getSession().invalidate();
		return R.ok("退出成功");
	}
	/**
     * 密码重置
     */
    @IgnoreAuth
	@RequestMapping(value = "/resetPass")
    public R resetPass(String username, HttpServletRequest request){
    	UserEntity user = userService.selectOne(new EntityWrapper<UserEntity>().eq("username", username));
    	if(user==null) {
    		return R.error("账号不存在");
    	}
    	user.setPassword("123456");
        userService.update(user,null);
        return R.ok("密码已重置为:123456");
    }
	/**
     * 列表
     */
    @RequestMapping("/page")
    public R page(@RequestParam Map<String, Object> params,UserEntity user){
        EntityWrapper<UserEntity> ew = new EntityWrapper<UserEntity>();
    	PageUtils page = userService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.allLike(ew, user), params), params));
        return R.ok().put("data", page);
    }
	/**
     * 列表
     */
    @RequestMapping("/list")
    public R list( UserEntity user){
       	EntityWrapper<UserEntity> ew = new EntityWrapper<UserEntity>();
      	ew.allEq(MPUtil.allEQMapPre( user, "user"));
        return R.ok().put("data", userService.selectListView(ew));
    }
    /**
     * 信息
     */
    @RequestMapping("/info/{id}")
    public R info(@PathVariable("id") String id){
        UserEntity user = userService.selectById(id);
        return R.ok().put("data", user);
    }
    /**
     * 获取用户的session用户信息
     */
    @RequestMapping("/session")
    public R getCurrUser(HttpServletRequest request){
    	Long id = (Long)request.getSession().getAttribute("userId");
        UserEntity user = userService.selectById(id);
        return R.ok().put("data", user);
    }
    /**
     * 保存
     */
    @PostMapping("/save")
    public R save(@RequestBody UserEntity user){
//    	ValidatorUtils.validateEntity(user);
    	if(userService.selectOne(new EntityWrapper<UserEntity>().eq("username", user.getUsername())) !=null) {
    		return R.error("用户已存在");
    	}
        userService.insert(user);
        return R.ok();
    }
    /**
     * 修改
     */
    @RequestMapping("/update")
    public R update(@RequestBody UserEntity user){
//        ValidatorUtils.validateEntity(user);
    	UserEntity u = userService.selectOne(new EntityWrapper<UserEntity>().eq("username", user.getUsername()));
    	if(u!=null && u.getId()!=user.getId() && u.getUsername().equals(user.getUsername())) {
    		return R.error("用户名已存在。");
    	}
        userService.updateById(user);//全部更新
        return R.ok();
    }
    /**
     * 删除
     */
    @RequestMapping("/delete")
    public R delete(@RequestBody Long[] ids){
        userService.deleteBatchIds(Arrays.asList(ids));
        return R.ok();
    }
}
/**
 * 订单
 * 后端接口
 * @author 小孟v:jishulearn
 * @email
 * @date 2022-06-26 09:41:24
 */
@RestController
@RequestMapping("/orders")
public class OrdersController {
    @Autowired
    private OrdersService ordersService;
    @Autowired
    private CaipinxinxiService caipinxinxiService;
    /**
     * 后端列表
     */
    @RequestMapping("/page")
    public R page(@RequestParam Map<String, Object> params,OrdersEntity orders,
		HttpServletRequest request){
    	if(!request.getSession().getAttribute("role").toString().equals("管理员")) {
    		orders.setUserid((Long)request.getSession().getAttribute("userId"));
    	}
        EntityWrapper<OrdersEntity> ew = new EntityWrapper<OrdersEntity>();
		PageUtils page = ordersService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, orders), params), params));
        return R.ok().put("data", page);
    }
    /**
     * 前端列表
     */
    @RequestMapping("/list")
    public R list(@RequestParam Map<String, Object> params,OrdersEntity orders, HttpServletRequest request){
        EntityWrapper<OrdersEntity> ew = new EntityWrapper<OrdersEntity>();
		PageUtils page = ordersService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, orders), params), params));
        return R.ok().put("data", page);
    }
	/**
     * 列表
     */
    @RequestMapping("/lists")
    public R list( OrdersEntity orders){
       	EntityWrapper<OrdersEntity> ew = new EntityWrapper<OrdersEntity>();
      	ew.allEq(MPUtil.allEQMapPre( orders, "orders"));
        return R.ok().put("data", ordersService.selectListView(ew));
    }
	 /**
     * 查询
     */
    @RequestMapping("/query")
    public R query(OrdersEntity orders){
        EntityWrapper< OrdersEntity> ew = new EntityWrapper< OrdersEntity>();
 		ew.allEq(MPUtil.allEQMapPre( orders, "orders"));
		OrdersView ordersView =  ordersService.selectView(ew);
		return R.ok("查询订单成功").put("data", ordersView);
    }
    /**
     * 后端详情
     */
    @RequestMapping("/info/{id}")
    public R info(@PathVariable("id") Long id){
        OrdersEntity orders = ordersService.selectById(id);
        return R.ok().put("data", orders);
    }
    /**
     * 前端详情
     */
    @RequestMapping("/detail/{id}")
    public R detail(@PathVariable("id") Long id){
        OrdersEntity orders = ordersService.selectById(id);
        return R.ok().put("data", orders);
    }
    /**
     * 后端保存
     */
    @RequestMapping("/save")
    public R save(@RequestBody OrdersEntity orders, HttpServletRequest request){
    	orders.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());
    	//ValidatorUtils.validateEntity(orders);
    	orders.setUserid((Long)request.getSession().getAttribute("userId"));
        ordersService.insert(orders);
        return R.ok();
    }
    /**
     * 前端保存
     */
    @RequestMapping("/add")
    public R add(@RequestBody OrdersEntity orders, HttpServletRequest request){
    	orders.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());
    	//ValidatorUtils.validateEntity(orders);
        CaipinxinxiEntity caipinxinxiEntity = caipinxinxiService.selectById(orders.getGoodid());
        if(caipinxinxiEntity.getStore()<orders.getBuynumber()){
            return R.error("库存不足");
        }
        caipinxinxiEntity.setStore(caipinxinxiEntity.getStore()-orders.getBuynumber());
        caipinxinxiEntity.setSell(caipinxinxiEntity.getSell()+orders.getBuynumber());
        caipinxinxiService.updateById(caipinxinxiEntity);
        ordersService.insert(orders);
        return R.ok();
    }
    /**
     * 修改
     */
    @RequestMapping("/update")
    public R update(@RequestBody OrdersEntity orders, HttpServletRequest request){
        //ValidatorUtils.validateEntity(orders);
        ordersService.updateById(orders);//全部更新
        return R.ok();
    }

Das obige ist der detaillierte Inhalt vonSo implementieren Sie das Bestell-Applet in SpringBoot. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme
Dieser Artikel ist reproduziert unter:亿速云. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen
Was sind die Vorteile der Verwendung von Bytecode gegenüber dem nativen Code für die Unabhängigkeit von Plattform?Was sind die Vorteile der Verwendung von Bytecode gegenüber dem nativen Code für die Unabhängigkeit von Plattform?Apr 30, 2025 am 12:24 AM

BytecodeachieVesplattformindependencyBeineingexecutedByavirtualMachine (VM), ZulassencodetorunonanyPlatformWiththeApprotecuse -Forexample, JavabytecodecanrunonanyDeviceWithajvm, Enabling "Writeonce, Runanywhere," Funktionalität "Funktionalität" Funktionalität "Funktionalität" Funktionalität "Funktionalität" Funktionalität "Funktionalität" Funktionalität "Funktionalität" functionaly.- "Funktionalität" Funktionalität "

Ist Java wirklich 100% plattformunabhängig? Warum oder warum nicht?Ist Java wirklich 100% plattformunabhängig? Warum oder warum nicht?Apr 30, 2025 am 12:18 AM

Java kann keine 100% ige Plattformunabhängigkeit erreichen, aber die Unabhängigkeit der Plattform wird über JVM und Bytecode implementiert, um sicherzustellen, dass der Code auf verschiedenen Plattformen ausgeführt wird. Spezifische Implementierungen umfassen: 1. Zusammenstellung in Bytecode; 2. Interpretation und Ausführung von JVM; 3. Konsistenz der Standardbibliothek. JVM-Implementierungsunterschiede, Betriebssystem- und Hardwareunterschiede sowie die Kompatibilität von Bibliotheken von Drittanbietern können sich jedoch auf die Unabhängigkeit der Plattform auswirken.

Wie unterstützt Javas Plattform -Unabhängigkeits -Code -Wartbarkeit?Wie unterstützt Javas Plattform -Unabhängigkeits -Code -Wartbarkeit?Apr 30, 2025 am 12:15 AM

Java realisiert die Unabhängigkeit der Plattform durch "einmal schreiben, überall rennen" und verbessert die Code -Wartbarkeit: 1. REUSE der Code und reduziert die doppelte Entwicklung; 2. Niedrige Wartungskosten, es ist nur eine Änderung erforderlich; 3. Die Effizienz der High -Team -Kollaboration ist hoch und bequem für den Wissensaustausch.

Was sind die Herausforderungen bei der Erstellung eines JVM für eine neue Plattform?Was sind die Herausforderungen bei der Erstellung eines JVM für eine neue Plattform?Apr 30, 2025 am 12:15 AM

Zu den Hauptherausforderungen, denen sich eine JVM auf einer neuen Plattform erstellen, gehören Hardwarekompatibilität, Kompatibilität für Betriebssysteme und Leistungsoptimierung. 1. Hardwarekompatibilität: Es ist erforderlich, sicherzustellen, dass das JVM den Prozessoranweisungssatz der neuen Plattform wie RISC-V korrekt verwenden kann. 2. Betriebssystemkompatibilität: Die JVM muss die System -API der neuen Plattform korrekt aufrufen, z. B. Linux. 3. Leistungsoptimierung: Leistungstests und -abstimmungen sind erforderlich, und die Strategie zur Müllsammlung wird angepasst, um sich an die Speichermerkmale der neuen Plattform anzupassen.

Wie versucht die Javafx -Bibliothek, Plattformkonsistenzen in der GUI -Entwicklung zu beheben?Wie versucht die Javafx -Bibliothek, Plattformkonsistenzen in der GUI -Entwicklung zu beheben?Apr 30, 2025 am 12:01 AM

JavafxeffectivyadDresSplatforminconsistencieSinguidevelopmentByusingAPLATFORM-AGNOSTICSCENGRAPHANDCSSSTYLING.1) ItabstractSpecifificSthroughascenegraph, SorteConsistentrendingacrosswindows, Macos undlinux.2) csSstylingallowlowlowlows

Erklären Sie, wie die JVM als Vermittler zwischen dem Java -Code und dem zugrunde liegenden Betriebssystem fungiert.Erklären Sie, wie die JVM als Vermittler zwischen dem Java -Code und dem zugrunde liegenden Betriebssystem fungiert.Apr 29, 2025 am 12:23 AM

JVM arbeitet mit dem Konvertieren von Java -Code in Maschinencode und Verwaltung von Ressourcen. 1) Ladeklasse: Laden Sie die .class -Datei in den Speicher. 2) Laufzeitdatenbereich: Speicherbereich verwalten. 3) Ausführungs Engine: Ausführungsbytecode interpretieren oder kompilieren. 4) Lokale Methodenschnittstelle: Interagieren Sie mit dem Betriebssystem über JNI.

Erklären Sie die Rolle der Java Virtual Machine (JVM) in der Unabhängigkeit der Plattform von Java.Erklären Sie die Rolle der Java Virtual Machine (JVM) in der Unabhängigkeit der Plattform von Java.Apr 29, 2025 am 12:21 AM

Mit JVM kann Java auf Plattformen rennen. 1) JVM lädt, validiert und führt Bytecode aus. 2) Die Arbeit von JVM umfasst Klassenbelastung, Bytecode -Überprüfung, Interpretationsausführung und Speicherverwaltung. 3) JVM unterstützt erweiterte Funktionen wie dynamisches Klassenbelastung und Reflexion.

Welche Schritte würden Sie unternehmen, um sicherzustellen, dass eine Java -Anwendung in verschiedenen Betriebssystemen korrekt ausgeführt wird?Welche Schritte würden Sie unternehmen, um sicherzustellen, dass eine Java -Anwendung in verschiedenen Betriebssystemen korrekt ausgeführt wird?Apr 29, 2025 am 12:11 AM

Java -Anwendungen können in verschiedenen Betriebssystemen in den folgenden Schritten ausgeführt werden: 1) Verwenden Sie die Datei- oder Pfadeklasse, um Dateipfade zu verarbeiten; 2) Umgebungsvariablen durch system.getenv () einstellen und erhalten; 3) Verwenden Sie Maven oder Gradle, um Abhängigkeiten zu verwalten und zu testen. Die plattformübergreifenden Funktionen von Java beruhen auf der Abstraktionsschicht der JVM, erfordern jedoch eine manuelle Handhabung bestimmter Betriebssystem-spezifischer Funktionen.

See all articles

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heiße Werkzeuge

Sicherer Prüfungsbrowser

Sicherer Prüfungsbrowser

Safe Exam Browser ist eine sichere Browserumgebung für die sichere Teilnahme an Online-Prüfungen. Diese Software verwandelt jeden Computer in einen sicheren Arbeitsplatz. Es kontrolliert den Zugriff auf alle Dienstprogramme und verhindert, dass Schüler nicht autorisierte Ressourcen nutzen.

EditPlus chinesische Crack-Version

EditPlus chinesische Crack-Version

Geringe Größe, Syntaxhervorhebung, unterstützt keine Code-Eingabeaufforderungsfunktion

SublimeText3 Linux neue Version

SublimeText3 Linux neue Version

SublimeText3 Linux neueste Version

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

PHPStorm Mac-Version

PHPStorm Mac-Version

Das neueste (2018.2.1) professionelle, integrierte PHP-Entwicklungstool