added intercepting filter and changes
This commit is contained in:
parent
aca75584d7
commit
2392d6caac
BIN
intercepting-filter/etc/Intercepting-filter.png
Normal file
BIN
intercepting-filter/etc/Intercepting-filter.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 82 KiB |
74
intercepting-filter/pom.xml
Normal file
74
intercepting-filter/pom.xml
Normal file
@ -0,0 +1,74 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||||
|
<modelVersion>4.0.0</modelVersion>
|
||||||
|
|
||||||
|
<groupId>com.iluwatar</groupId>
|
||||||
|
<artifactId>java-design-patterns</artifactId>
|
||||||
|
<version>1.0-SNAPSHOT</version>
|
||||||
|
<packaging>pom</packaging>
|
||||||
|
|
||||||
|
<properties>
|
||||||
|
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
|
||||||
|
</properties>
|
||||||
|
<modules>
|
||||||
|
<module>abstract-factory</module>
|
||||||
|
<module>builder</module>
|
||||||
|
<module>factory-method</module>
|
||||||
|
<module>prototype</module>
|
||||||
|
<module>singleton</module>
|
||||||
|
<module>adapter</module>
|
||||||
|
<module>bridge</module>
|
||||||
|
<module>composite</module>
|
||||||
|
<module>decorator</module>
|
||||||
|
<module>facade</module>
|
||||||
|
<module>flyweight</module>
|
||||||
|
<module>proxy</module>
|
||||||
|
<module>chain</module>
|
||||||
|
<module>command</module>
|
||||||
|
<module>interpreter</module>
|
||||||
|
<module>iterator</module>
|
||||||
|
<module>mediator</module>
|
||||||
|
<module>memento</module>
|
||||||
|
<module>model-view-presenter</module>
|
||||||
|
<module>observer</module>
|
||||||
|
<module>state</module>
|
||||||
|
<module>strategy</module>
|
||||||
|
<module>template-method</module>
|
||||||
|
<module>visitor</module>
|
||||||
|
<module>double-checked-locking</module>
|
||||||
|
<module>servant</module>
|
||||||
|
<module>service-locator</module>
|
||||||
|
<module>null-object</module>
|
||||||
|
<module>event-aggregator</module>
|
||||||
|
<module>callback</module>
|
||||||
|
<module>execute-around</module>
|
||||||
|
<module>property</module>
|
||||||
|
</modules>
|
||||||
|
|
||||||
|
<dependencyManagement>
|
||||||
|
<dependencies>
|
||||||
|
<dependency>
|
||||||
|
<groupId>junit</groupId>
|
||||||
|
<artifactId>junit</artifactId>
|
||||||
|
<version>4.11</version>
|
||||||
|
<scope>test</scope>
|
||||||
|
</dependency>
|
||||||
|
</dependencies>
|
||||||
|
</dependencyManagement>
|
||||||
|
|
||||||
|
<build>
|
||||||
|
<plugins>
|
||||||
|
<!-- Tell maven to compile using Java 1.7 -->
|
||||||
|
<plugin>
|
||||||
|
<groupId>org.apache.maven.plugins</groupId>
|
||||||
|
<artifactId>maven-compiler-plugin</artifactId>
|
||||||
|
<version>3.0</version>
|
||||||
|
<configuration>
|
||||||
|
<source>1.7</source>
|
||||||
|
<target>1.7</target>
|
||||||
|
</configuration>
|
||||||
|
</plugin>
|
||||||
|
</plugins>
|
||||||
|
</build>
|
||||||
|
|
||||||
|
</project>
|
245
intercepting-filter/src/main/App.java
Normal file
245
intercepting-filter/src/main/App.java
Normal file
@ -0,0 +1,245 @@
|
|||||||
|
import java.util.*;
|
||||||
|
import javax.swing.*;
|
||||||
|
import javax.swing.table.*;
|
||||||
|
import java.awt.*;
|
||||||
|
import java.awt.event.*;
|
||||||
|
public class App{
|
||||||
|
public static void main(String[] args){
|
||||||
|
FilterManager filterManager = new FilterManager(new Target());
|
||||||
|
filterManager.setFilter(new NameFilter());
|
||||||
|
filterManager.setFilter(new ContactFilter());
|
||||||
|
filterManager.setFilter(new AddressFilter());
|
||||||
|
filterManager.setFilter(new DepositFilter());
|
||||||
|
filterManager.setFilter(new OrderFilter());
|
||||||
|
|
||||||
|
Client client = new Client();
|
||||||
|
client.setFilterManager(filterManager);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
interface Filter{
|
||||||
|
public String execute(String[] request);
|
||||||
|
}
|
||||||
|
|
||||||
|
class NameFilter implements Filter{
|
||||||
|
public String execute(String[] request){
|
||||||
|
if(request[0].equals("") || request[0].matches(".*[^\\w|\\s]+.*")){
|
||||||
|
return null;
|
||||||
|
}else return request[0];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class ContactFilter implements Filter{
|
||||||
|
public String execute(String[] request){
|
||||||
|
if(request[1].equals("") || request[1].matches(".*[^\\d]+.*") || request[1].length() != 11){
|
||||||
|
return null;
|
||||||
|
}else return request[1];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class AddressFilter implements Filter{
|
||||||
|
public String execute(String[] request){
|
||||||
|
if(request[2].equals("")){
|
||||||
|
return null;
|
||||||
|
}else return request[2];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class DepositFilter implements Filter{
|
||||||
|
public String execute(String[] request){
|
||||||
|
if(request[3].equals("")){
|
||||||
|
return null;
|
||||||
|
}else return request[3];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class OrderFilter implements Filter{
|
||||||
|
public String execute(String[] request){
|
||||||
|
if(request[4].equals("")){
|
||||||
|
return null;
|
||||||
|
}else return request[4];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class Target extends JFrame{
|
||||||
|
JTable jt;
|
||||||
|
JScrollPane jsp;
|
||||||
|
DefaultTableModel dtm;
|
||||||
|
JButton del;
|
||||||
|
public Target(){
|
||||||
|
super("Order System");
|
||||||
|
setDefaultCloseOperation(EXIT_ON_CLOSE);
|
||||||
|
setSize(640,480);
|
||||||
|
dtm = new DefaultTableModel(new Object[]{"Name", "Contact Number", "Address", "Deposit Number", "Order"},0);
|
||||||
|
jt = new JTable(dtm);
|
||||||
|
del = new JButton("Delete");
|
||||||
|
setup();
|
||||||
|
}
|
||||||
|
private void setup(){
|
||||||
|
setLayout(new BorderLayout());
|
||||||
|
JPanel bot = new JPanel();
|
||||||
|
add(jt.getTableHeader(), BorderLayout.NORTH);
|
||||||
|
bot.setLayout(new BorderLayout());
|
||||||
|
bot.add(del, BorderLayout.EAST);
|
||||||
|
add(bot, BorderLayout.SOUTH);
|
||||||
|
jsp = new JScrollPane(jt);
|
||||||
|
jsp.setPreferredSize(new Dimension(500,250));
|
||||||
|
add(jsp, BorderLayout.CENTER);
|
||||||
|
|
||||||
|
del.addActionListener(new DListener());
|
||||||
|
|
||||||
|
JRootPane rootPane = SwingUtilities.getRootPane(del);
|
||||||
|
rootPane.setDefaultButton(del);
|
||||||
|
setVisible(true);
|
||||||
|
}
|
||||||
|
public void execute(String[] request){
|
||||||
|
//System.out.println(request[4]);
|
||||||
|
dtm.addRow(new Object[]{request[0],request[1],request[2],request[3],request[4]});
|
||||||
|
}
|
||||||
|
|
||||||
|
class DListener implements ActionListener{
|
||||||
|
@Override
|
||||||
|
public void actionPerformed(ActionEvent e){
|
||||||
|
int temp = jt.getSelectedRow();
|
||||||
|
if(temp == -1) return;
|
||||||
|
int temp2 = jt.getSelectedRowCount();
|
||||||
|
for(int i = 0; i < temp2; i++){
|
||||||
|
dtm.removeRow(temp);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class FilterChain{
|
||||||
|
private ArrayList<Filter> filters = new ArrayList<Filter>();
|
||||||
|
private Target target;
|
||||||
|
|
||||||
|
public void addFilter(Filter filter){
|
||||||
|
filters.add(filter);
|
||||||
|
}
|
||||||
|
|
||||||
|
public String execute(String request){
|
||||||
|
String tempout[] = new String[filters.size()];
|
||||||
|
|
||||||
|
String tempin[] = request.split("&");
|
||||||
|
int i = 0;
|
||||||
|
try{
|
||||||
|
for(Filter filter:filters){
|
||||||
|
tempout[i] = null;
|
||||||
|
tempout[i++] = filter.execute(tempin);
|
||||||
|
//System.out.println(tempout[i]);
|
||||||
|
}
|
||||||
|
}catch(Exception e){
|
||||||
|
return "NOT ENOUGHT INPUT";
|
||||||
|
}
|
||||||
|
|
||||||
|
if(tempout[4] == null){
|
||||||
|
return "INVALID ORDER!";
|
||||||
|
}else if(tempout[3] == null){
|
||||||
|
return "INVALID DEPOSIT NUMBER!";
|
||||||
|
}else if(tempout[2] == null){
|
||||||
|
return "INVALID ADRDESS!";
|
||||||
|
}else if(tempout[1] == null){
|
||||||
|
return "INVALID Contact Number!";
|
||||||
|
}else if(tempout[0] == null){
|
||||||
|
return "INVALID Name!";
|
||||||
|
}else{
|
||||||
|
target.execute(tempout);
|
||||||
|
return "RUNNING...";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setTarget(Target target){
|
||||||
|
this.target = target;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class FilterManager{
|
||||||
|
FilterChain filterChain;
|
||||||
|
|
||||||
|
public FilterManager(Target target){
|
||||||
|
filterChain = new FilterChain();
|
||||||
|
filterChain.setTarget(target);
|
||||||
|
}
|
||||||
|
public void setFilter(Filter filter){
|
||||||
|
filterChain.addFilter(filter);
|
||||||
|
}
|
||||||
|
public String filterRequest(String request){
|
||||||
|
return filterChain.execute(request);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class Client extends JFrame{
|
||||||
|
FilterManager filterManager;
|
||||||
|
JLabel jl;
|
||||||
|
JTextField[] jtfarr;
|
||||||
|
JTextArea[] jtaarr;
|
||||||
|
JButton[] buttarr;
|
||||||
|
public Client(){
|
||||||
|
super("Client System");
|
||||||
|
setDefaultCloseOperation(EXIT_ON_CLOSE);
|
||||||
|
setSize(300,300);
|
||||||
|
jl = new JLabel("RUNNING...");
|
||||||
|
jtfarr = new JTextField[3];
|
||||||
|
for(int i = 0; i < 3; i++){
|
||||||
|
jtfarr[i] = new JTextField();
|
||||||
|
}
|
||||||
|
jtaarr = new JTextArea[2];
|
||||||
|
for(int i = 0; i < 2; i++){
|
||||||
|
jtaarr[i] = new JTextArea();
|
||||||
|
}
|
||||||
|
buttarr = new JButton[2];
|
||||||
|
buttarr[0] = new JButton("Clear");
|
||||||
|
buttarr[1] = new JButton("Process");
|
||||||
|
|
||||||
|
setup();
|
||||||
|
}
|
||||||
|
private void setup(){
|
||||||
|
setLayout(new BorderLayout());
|
||||||
|
JPanel panel = new JPanel();
|
||||||
|
add(jl,BorderLayout.SOUTH);
|
||||||
|
add(panel, BorderLayout.CENTER);
|
||||||
|
panel.setLayout(new GridLayout(6,2));
|
||||||
|
panel.add(new JLabel("Name"));
|
||||||
|
panel.add(jtfarr[0]);
|
||||||
|
panel.add(new JLabel("Contact Number"));
|
||||||
|
panel.add(jtfarr[1]);
|
||||||
|
panel.add(new JLabel("Address"));
|
||||||
|
panel.add(jtaarr[0]);
|
||||||
|
panel.add(new JLabel("Deposit Number"));
|
||||||
|
panel.add(jtfarr[2]);
|
||||||
|
panel.add(new JLabel("Order"));
|
||||||
|
panel.add(jtaarr[1]);
|
||||||
|
panel.add(buttarr[0]);
|
||||||
|
panel.add(buttarr[1]);
|
||||||
|
|
||||||
|
buttarr[0].addActionListener(new ActionListener(){
|
||||||
|
@Override
|
||||||
|
public void actionPerformed(ActionEvent e){
|
||||||
|
for(JTextArea i : jtaarr){
|
||||||
|
i.setText("");
|
||||||
|
}
|
||||||
|
for(JTextField i : jtfarr){
|
||||||
|
i.setText("");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
buttarr[1].addActionListener(new ActionListener(){
|
||||||
|
@Override
|
||||||
|
public void actionPerformed(ActionEvent e){
|
||||||
|
jl.setText(sendRequest(jtfarr[0].getText()+"&"+jtfarr[1].getText()+"&"+jtaarr[0].getText()+"&"+jtfarr[2].getText()+"&"+jtaarr[1].getText()));
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
JRootPane rootPane = SwingUtilities.getRootPane(buttarr[1]);
|
||||||
|
rootPane.setDefaultButton(buttarr[1]);
|
||||||
|
setVisible(true);
|
||||||
|
}
|
||||||
|
public void setFilterManager(FilterManager filterManager){
|
||||||
|
this.filterManager = filterManager;
|
||||||
|
}
|
||||||
|
public String sendRequest(String request){
|
||||||
|
return filterManager.filterRequest(request);
|
||||||
|
}
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user