/URLNet

URLNet

Primary LanguageJupyter NotebookApache License 2.0Apache-2.0

URLNet

Mainly used for interpret URLNet

Usage

interpret original model: check_bias_word-Copy2.ipynb

interpret new adversairla model: check_bias_word-Copy3.ipynb

Results

original: img/highlight_token.pdf

our: img/highlight_token11.pdf, img/highlight_token22.pdf, img/highlight_token33.pdf

Introduction

This is an implementation of URLNet - Learning a URL Representation with Deep Learning for Malicious URL Detection https://arxiv.org/abs/1802.03162

URLNet is a convolutional neural network (CNN) based model used to detect malicious URLs. The model exploits features of URL text string at both character and word levels.

Resources

URLNet requires Python 3.6 and the following packages:

  • tensorflow 1.8

  • tflearn 0.3

  • numpy 1.14

Model Designs

Sample Commands

In all datasets for training or testing, each line includes the label and the URL text string following the template:

<URL label><tab><URL string>

Example:

+1  http://www.exampledomain.com/urlpath/...

-1  http://www.exampledomain.com/urlpath/...

The URL label is either +1 (Malicious) or -1 (Benign).

The model can be trained by running the following command:

python train.py --data.data_dir <data_file_directory> --data.dev_pct 0.2 --data.delimit_mode <url_delimit_mode> --data.min_word_freq <url_min_word_freq> \
--model.emb_mode <embedding_mode> --model.emb_dim <size_of_embedding_dimensions> --model.filter_sizes <convolutional_filter_sizes_separated_by_comma> \
--train.nb_epochs <nb_of_training_epochs> --train.batch_size <nb_of_urls_per_batch> \
--log.print_every <print_acc_after_this_nb_steps> --log.eval_every <evaluate_on_dev_set_after_this_nb_steps> --log.checkpoint_every <checkpoint_model_after_this_nb_steps> --log.output_dir <model_output_folder_directory>

The training will save all the related word and character dictionaries into an output folder, and the model checkpoints are saved into checkpoints/ folder. By default, maximum 5 checkpoints are stored in the folder.

The model can be tested by running the following command:

python test.py --data.data_dir <data_file_directory> --data.delimit_mode <url_delimit_mode> --data.word_dict_dir <word_dictionary_directory> --data.subword_dict_dir <character_in_word_dictionary_directory> --data.char_dict_dir <character_dictionary_directory> \
--log.checkpoint_dir <model_checkpoint_directory> --log.output_dir <test_result_directory> \
--model.emb_mode <embedding_mode> --model.emb_dim <nb_of_embedding_dimensions> \
--test.batch_size <nb_of_urls_per_batch>

The test will save the test results for each URL, including 3 columns: label (original label), predict (prediction label), and score (softmax score). The orders of test results from top to bottom are the same as their orders in the test dataset. If the score is more than 0.5, prediction label is +1 (Malicious). Else, the prediction is -1 (Benign).

Example: ~~~~~~~~~~~~~~~~~~~~~~ label predict score

1 1 0.884

-1 -1 0.359 ~~~~~~~~~~~~~~~~~~~~~~

To obtain test metrics such as True Positive, False Positive, True Negative, False Negative, and the AUC curves, run the following command:

python auc.py --input_path <test_result_directory> --input_file
<test_result_file>

The command will output the test metrics into a file with the same name as the input_file but with an .auc extension.

Parameters

Training parameters include:

Parameter Description Default
data.max_len_words The maximum number of words in a URL. The URL is either truncated or padded with a <PADDING> token to reach this length. 200
data.max_len_chars The maximum number of characters in a URL. The URL is either truncted or padded with a <PADDING> character to reach this length. 200
data.max_len_subwords The maximum number of characters in each word in a URL. Each word is either truncated or padded with a <PADDING> character to reach this length. 20
data.min_word_freq Words that have frequency less than or equal to this parameter are considered as rare words, and represented as a single <UNKNOWN> token. 1
data.dev_pct Percentage of training data used for validation 0.001
data.data_dir Directory of the training dataset train_10000.txt
data.delimit_mode 0: delimit URL by special characters (i.e. non-alphanumerical characters), 1: delimit URL by special characters (i.e. non-alphanumerical characters) and treat each special characters as words 1
model.emb_dim Dimension size of word and character embedding. 32
model.emb_mode 1: only character-based CNN, 2: only word-based CNN, 3: character and word CNN, 4: character-level word CNN, 5: character and character-level word CNN 1
model.filter_sizes Sizes of convolutional filters. If more than one branches of CNN, all will have the same set of filter sizes. Separate the filter sizes by comma. 3,4,5,6
train.batch_size Number of URLs in each training batch 128
train.nb_epochs Number of training epochs 5
train.lr Learning rate 0.001
train.l2_reg_lambda regularization parameter of loss function 0
log.output_dir Output folder to save dictionaries and model checkpoints runs/10000/
log.print_every Output the training loss and accuracy after this number of batches 50
log.eval_every Evaluate the model on the validation set after this number of batches 500
log.checkpoint_every Checkpoint the model after this number of batches. Only save the model checkpoint if the validation loss is improved. 500

 

Test parameters include:

Parameter Description Default
data.max_len_words The maximum number of words in a URL. The URL is either truncated or padded with a <PADDING> token to reach this length. 200
data.max_len_chars The maximum number of characters in a URL. The URL is either truncted or padded with a <PADDING> character to reach this length. 200
data.max_len_subwords The maximum number of characters in each word in a URL. Each word is either truncated or padded with a <PADDING> character to reach this length. 20
data.delimit_mode 0: delimit URL by special characters (i.e. non-alphanumerical characters), 1: delimit URL by special characters (i.e. non-alphanumerical characters) and treat each special characters as words 1
data.data_dir Directory of the test dataset test_1000.txt
data.word_dict_dir Directory of the word dictionary file. Dictionary file is in pickle extension .p runs/10000/words_dict.p
data.char_dict_dir Directory of the character dictionary file. Dictionary file is in pickle extension .p runs/10000/chars_dict.p
data.subword_dict_dir Directory of the character-in-word dictionary file. Dictionary file is in pickle extension .p runs/10000/ngrams_dict.p
model.emb_dim Dimension size of word and character embedding. 32
model.emb_mode 1: only character-based CNN, 2: only word-based CNN, 3: character and word CNN, 4: character-level word CNN, 5: character and character-level word CNN 1
test.batch_size Number of URLs in each test batch 128
log.checkpoint_dir Directory of the model checkpoints runs/10000/checkpoints/
log.output_dir Directory of the test results runs/10000/train_10000_test_1000.txt

The test parameters such as model.emb_mode and data.delimit_mode have to be consistent with the trained model to get accurate test results.

Refer to the file run.sh for example commands.

Acknowledgement

We are very grateful to our collaborators VirusTotal, for providing us access to their data, without which this research would not have been possible.