Rumah  >  Artikel  >  Java  >  Pengesanan masa nyata data borang dan pencegahan penyerahan berulang menggunakan Java

Pengesanan masa nyata data borang dan pencegahan penyerahan berulang menggunakan Java

WBOY
WBOYasal
2023-08-08 16:01:42831semak imbas

Pengesanan masa nyata data borang dan pencegahan penyerahan berulang menggunakan Java

Java melaksanakan pengesanan masa nyata dan pencegahan penyerahan berulang data borang

Dalam pembangunan web, pengesanan masa nyata dan pencegahan penyerahan berulang data borang adalah masalah biasa. Apabila pengguna mengisi borang, kami perlu mengesan data yang dimasukkan oleh pengguna dalam masa nyata untuk memberikan gesaan ralat serta-merta, penyerahan berulang boleh menyebabkan konflik data atau pembaziran sumber yang tidak perlu, jadi langkah yang sepadan perlu diambil untuk mengelakkan pertindihan. Pemprosesan penyerahan. Artikel ini akan memperkenalkan cara menggunakan Java untuk melaksanakan pengesanan masa nyata data borang dan menghalang penyerahan berulang, serta disertakan dengan contoh kod.

  1. Pengesanan masa nyata data borang

Dalam proses pengesanan masa nyata data borang, kami boleh melaksanakan pengesahan masa nyata pada pihak pelanggan melalui JavaScript untuk mengoptimumkan pengalaman pengguna. Berikut ialah contoh mudah yang menggunakan JavaScript untuk mengesan dalam masa nyata sama ada format nombor telefon mudah alih yang dimasukkan oleh pengguna adalah betul:

<script>
function checkPhoneNumber() {
    var phoneNumber = document.getElementById("phoneNumber").value;
    var phoneRegex = /^1[3-9]d{9}$/;
    
    if (!phoneRegex.test(phoneNumber)) {
        document.getElementById("phoneNumberError").innerHTML = "手机号码格式不正确";
    } else {
        document.getElementById("phoneNumberError").innerHTML = "";
    }
}
</script>

<form>
    <input type="text" id="phoneNumber" onkeyup="checkPhoneNumber()">
    <span id="phoneNumberError"></span>
    <button type="submit">提交</button>
</form>

Melalui fungsi pengikatan acara onkeyup checkPhoneNumber, apabila pengguna memasukkan nombor telefon bimbit, ia akan disahkan dalam masa nyata sama ada format nombor telefon mudah alih adalah betul, dan Paparkan mesej ralat yang sepadan pada halaman.

Sudah tentu, pengesahan masa nyata di bahagian pelanggan hanya untuk memberikan pengalaman pengguna yang lebih baik dan tidak boleh menggantikan pengesahan di bahagian pelayan. Data borang perlu disahkan semula pada bahagian pelayan untuk mengelakkan penyerahan berniat jahat atau memintas pengesahan pihak pelanggan.

  1. Menghalang penyerahan berulang data borang

Untuk mengelakkan penyerahan data borang berulang, kami boleh memperkenalkan mekanisme Token di bahagian pelayan. Token ialah rentetan yang dijana secara rawak yang diserahkan kepada pelayan sebagai salah satu parameter borang setiap kali borang diserahkan. Apabila pelayan memproses permintaan borang, ia akan menyemak sama ada Token itu sah, ia akan memproses permintaan tersebut. Jika ia tidak sah, ia akan menolak permintaan tersebut.

Berikut ialah contoh mudah untuk mengelakkan penyerahan berulang:

@Controller
@RequestMapping("/form")
public class FormController {

    @Autowired
    private TokenService tokenService;

    @RequestMapping(method = RequestMethod.GET)
    public String showForm(Model model) {
        String token = tokenService.generateToken();
        model.addAttribute("token", token);
        return "form";
    }

    @RequestMapping(method = RequestMethod.POST)
    public String processForm(@RequestParam("token") String token) {
        if (!tokenService.isValidToken(token)) {
            return "error";
        }
        // 处理表单请求
        return "success";
    }
}

@Component
public class TokenService {
    private Set<String> tokens = new HashSet<>();

    public String generateToken() {
        String token = UUID.randomUUID().toString();
        tokens.add(token);
        return token;
    }

    public boolean isValidToken(String token) {
        return tokens.remove(token);
    }
}

Dalam FormController, kami menjana Token melalui kaedah showForm dan meletakkan Token ke dalam Model dan menghantarnya ke halaman borang. Apabila borang diserahkan, Token dihantar ke pelayan sebagai parameter, dan kesahihan Token disahkan dalam kaedah processForm. Jika Token tidak sah, permintaan borang akan ditolak untuk diproses.

Kelas TokenService digunakan untuk menjana dan mengesahkan Token. Kami menggunakan koleksi Set untuk menyimpan Token yang sah Apabila mengesahkan Token, ia dikeluarkan daripada set untuk memastikan setiap Token hanya boleh digunakan sekali.

Dengan memperkenalkan mekanisme Token, kami boleh menghalang penyerahan data borang berulang dengan berkesan dan memastikan integriti dan keselamatan data sistem.

Ringkasan:

Dalam pembangunan web, pengesanan masa nyata data borang dan pencegahan penyerahan berulang adalah isu penting. Pengesahan masa nyata pelanggan melalui JavaScript boleh memberikan pengalaman pengguna yang baik dengan memperkenalkan mekanisme Token, penyerahan data borang yang berulang dapat dicegah dengan berkesan. Melalui pengenalan dan contoh artikel ini, saya percaya pembaca akan mempunyai pemahaman yang lebih mendalam tentang pengesanan masa nyata data borang dan pencegahan penyerahan berulang di Jawa.

Atas ialah kandungan terperinci Pengesanan masa nyata data borang dan pencegahan penyerahan berulang menggunakan Java. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn